<?xml version="1.0"?>
<feed xmlns="http://www.w3.org/2005/Atom" xml:lang="en-GB">
	<id>https://wiki.kram.nz/index.php?action=history&amp;feed=atom&amp;title=SE250%3Alab-6%3Amgha023</id>
	<title>SE250:lab-6:mgha023 - Revision history</title>
	<link rel="self" type="application/atom+xml" href="https://wiki.kram.nz/index.php?action=history&amp;feed=atom&amp;title=SE250%3Alab-6%3Amgha023"/>
	<link rel="alternate" type="text/html" href="https://wiki.kram.nz/index.php?title=SE250:lab-6:mgha023&amp;action=history"/>
	<updated>2026-04-28T14:59:45Z</updated>
	<subtitle>Revision history for this page on the wiki</subtitle>
	<generator>MediaWiki 1.45.3</generator>
	<entry>
		<id>https://wiki.kram.nz/index.php?title=SE250:lab-6:mgha023&amp;diff=7206&amp;oldid=prev</id>
		<title>Mark: 3 revision(s)</title>
		<link rel="alternate" type="text/html" href="https://wiki.kram.nz/index.php?title=SE250:lab-6:mgha023&amp;diff=7206&amp;oldid=prev"/>
		<updated>2008-11-03T05:20:06Z</updated>

		<summary type="html">&lt;p&gt;3 revision(s)&lt;/p&gt;
&lt;p&gt;&lt;b&gt;New page&lt;/b&gt;&lt;/p&gt;&lt;div&gt;==minimum==&lt;br /&gt;
 &lt;br /&gt;
Initially I had this :/*if (node == empty){&lt;br /&gt;
		       return ;&lt;br /&gt;
	               }&lt;br /&gt;
	               minimum( (*node)-&amp;gt;left) ;&lt;br /&gt;
	               return node;*/&lt;br /&gt;
&lt;br /&gt;
but that wasn&amp;#039;t really right...&lt;br /&gt;
Then I had:&lt;br /&gt;
  Node* minimum( Node* node ) {&lt;br /&gt;
  	while (*node != empty){&lt;br /&gt;
  	node = &amp;amp;(*node)-&amp;gt;left;&lt;br /&gt;
  	return node;&lt;br /&gt;
  	}&lt;br /&gt;
  return 0;&lt;br /&gt;
  }&lt;br /&gt;
==maximum==&lt;br /&gt;
Initially:&lt;br /&gt;
 /*if (node == empty){&lt;br /&gt;
 		return ;&lt;br /&gt;
 	}&lt;br /&gt;
 	//else return (*node)-&amp;gt; right;&lt;br /&gt;
 	maximum( (*node)-&amp;gt;right); */&lt;br /&gt;
 &lt;br /&gt;
Finally:&lt;br /&gt;
 &lt;br /&gt;
 Node* maximum( Node* node ) {&lt;br /&gt;
 		while (*node != empty){&lt;br /&gt;
 		node = &amp;amp;(*node)-&amp;gt;right;&lt;br /&gt;
 		return node;&lt;br /&gt;
  	}&lt;br /&gt;
 return 0;&lt;br /&gt;
 }&lt;br /&gt;
&lt;br /&gt;
==lookup==&lt;br /&gt;
&lt;br /&gt;
Initially:&lt;br /&gt;
*if (node == empty){&lt;br /&gt;
		return;&lt;br /&gt;
	}&lt;br /&gt;
	else lookup((*node)-&amp;gt;key, node);*/&lt;br /&gt;
&lt;br /&gt;
Finally:&lt;br /&gt;
&lt;br /&gt;
  Node* lookup( int key, Node* node ) {&lt;br /&gt;
  &lt;br /&gt;
  	if (*node != empty){&lt;br /&gt;
   	printf(&amp;quot;%d\n&amp;quot;, (*node)-&amp;gt;key);&lt;br /&gt;
 	lookup(&amp;amp;(*node)-&amp;gt;left);&lt;br /&gt;
  	lookup(&amp;amp;(*node)-&amp;gt;right);&lt;br /&gt;
        }&lt;br /&gt;
  	return 0;&lt;br /&gt;
  }&lt;br /&gt;
&lt;br /&gt;
==successor funtion:next_pre==&lt;br /&gt;
&lt;br /&gt;
 &lt;br /&gt;
 Node* next_pre( Node* node ) {&lt;br /&gt;
 	if ((*node)-&amp;gt;right != empty){&lt;br /&gt;
 	   return next_pre((*node)-&amp;gt;right);&lt;br /&gt;
        } &lt;br /&gt;
        return o;&lt;br /&gt;
 }&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
At this point I found this website [[Link Binary Search Tree]]http://www.personal.kent.edu/~rmuhamma/Algorithms/MyAlgorithms/binarySearchTree.htm&lt;br /&gt;
that had some useful explanation  that helped me get a better understanding of what was to be done.&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
==prev_pre==&lt;br /&gt;
&lt;br /&gt;
 Node* next_pre( Node* node ) {&lt;br /&gt;
 	&lt;br /&gt;
 	if ((*node)-&amp;gt;right != empty){&lt;br /&gt;
 		return next_pre((*node)-&amp;gt;right);&lt;br /&gt;
 	}&lt;br /&gt;
 	return 0;&lt;br /&gt;
 	&lt;br /&gt;
 }&lt;/div&gt;</summary>
		<author><name>Mark</name></author>
	</entry>
</feed>