Velocity Reviews - Computer Hardware Reviews

Velocity Reviews > Newsgroups > Programming > C++ > Binary tree Algorithm

Reply
Thread Tools

Binary tree Algorithm

 
 
Aris
Guest
Posts: n/a
 
      12-03-2005
Hello!
This is my problem.
I'm trying to make an inorder traversal algorithm for
a binary tree, not a recursive one, but using a stack.
Till now I got this:

void traverse(tree * p)
{
l: if(p==0) goto s;
push(p);
p=p->l; goto l;
r: visit(p);
p=p->r;
goto l;
s: if(top==0) goto x;
p=pop(); goto r;
x: ;
}

we call this function this way : traverse(root);
My question is :
how can I eliminate goto's?
Everything I've tryed is a mess.
I'll be greatfull if you help me.




 
Reply With Quote
 
 
 
 
Mike Wahler
Guest
Posts: n/a
 
      12-03-2005

"Aris" <> wrote in message
news:dmt2lt$988$...
> Hello!
> This is my problem.
> I'm trying to make an inorder traversal algorithm for
> a binary tree, not a recursive one, but using a stack.
> Till now I got this:
>
> void traverse(tree * p)
> {
> l: if(p==0) goto s;
> push(p);
> p=p->l; goto l;
> r: visit(p);
> p=p->r;
> goto l;
> s: if(top==0) goto x;
> p=pop(); goto r;
> x: ;
> }
>
> we call this function this way : traverse(root);
> My question is :
> how can I eliminate goto's?


do
{
while(p)
{
push(p);
p=p->l;
}

if(top)
{
p = pop();
visit(p);
p = p->r;
}
} while(top);

Or something like that (not tested).

-Mike


 
Reply With Quote
 
 
 
 
Alf P. Steinbach
Guest
Posts: n/a
 
      12-03-2005
* Aris:
> Hello!
> This is my problem.
> I'm trying to make an inorder traversal algorithm for
> a binary tree, not a recursive one, but using a stack.
> Till now I got this:
>
> void traverse(tree * p)
> {
> l: if(p==0) goto s;
> push(p);
> p=p->l; goto l;
> r: visit(p);
> p=p->r;
> goto l;
> s: if(top==0) goto x;
> p=pop(); goto r;
> x: ;
> }
>
> we call this function this way : traverse(root);
> My question is :
> how can I eliminate goto's?
> Everything I've tryed is a mess.
> I'll be greatfull if you help me.


I will assume that this is not HOMEWORK. But if it is then an answer
can still be helpful to others. Essentially, transform the code to
something less awful one small step at a time, preserving the code's
effect _exactly_ at each small step.

Let's start with the first label, 'l'. The 'if' there effects a jump
over the following code. So rearrange:

void traverse(tree * p)
{
l: if( p != 0 ) // if(p==0) goto s;
{
push(p);
p = p->l; goto l;
}
s: if( top == 0) goto x;
p = pop(); goto r;
r: visit(p);
p = p->r;
goto l;
x: ;
}

Now you have loop there, so express that as a loop:

void traverse(tree * p)
{
l: while( p != 0 )
{
push(p);
p = p->l;
}
s: if( top == 0) goto x;
p = pop(); goto r;
r: visit(p);
p = p->r;
goto l;
x: ;
}

The 'goto r' has no effect and so can be eliminated, along with the
labels 's' and 'r' which are then no longer referenced:

void traverse(tree * p)
{
l: while( p != 0 )
{
push(p);
p = p->l;
}
if( top == 0 ) goto x;
p = pop();
visit(p);
p = p->r;
goto l;
x: ;
}

That last goto is an outer loop, an infinite one which the goto in the
middle breaks out of:

void traverse(tree * p)
{
for( ;; )
{
while( p != 0 )
{
push(p);
p = p->l;
}
if( top == 0 ) goto x;
p = pop();
visit(p);
p = p->r;
}
x: ;
}

Finally replace the single remaining break-out-of goto with a break:

void traverse(tree * p)
{
for( ;; )
{
while( p != 0 )
{
push(p);
p = p->l;
}
if( top == 0 ) { break; }
p = pop();
visit(p);
p = p->r;
}
}

Now you can start to reason about correctness, e.g., what's that 'top'
in there? Is it perhaps a global modified by 'visit'? If so, then
that's evil and should be fixed, and if not so, then you have
non-working code.

--
A: Because it messes up the order in which people normally read text.
Q: Why is it such a bad thing?
A: Top-posting.
Q: What is the most annoying thing on usenet and in e-mail?
 
Reply With Quote
 
Aris
Guest
Posts: n/a
 
      12-04-2005
Not only a good answer but the way to face this problems
in the future.
Gratefull!


 
Reply With Quote
 
Hans Lohninger
Guest
Posts: n/a
 
      12-04-2005
A good introduction how to handle trees (and other data structures) can be
found in the free eBook "C++Course". Trees are discussed here:

http://www.vias.org/cppcourse/chap21_01.html

Regards,

Hans


=====================================
Hans Lohninger
EPINA GmbH - Software Development Lohninger
www.lohninger.com
mailto
fax: +43-2233-541945
======================================

"Aris" <> wrote in message
news:dmt2lt$988$...
> Hello!
> This is my problem.
> I'm trying to make an inorder traversal algorithm for
> a binary tree, not a recursive one, but using a stack.
> Till now I got this:
>
> void traverse(tree * p)
> {
> l: if(p==0) goto s;
> push(p);
> p=p->l; goto l;
> r: visit(p);
> p=p->r;
> goto l;
> s: if(top==0) goto x;
> p=pop(); goto r;
> x: ;
> }
>
> we call this function this way : traverse(root);
> My question is :
> how can I eliminate goto's?
> Everything I've tryed is a mess.
> I'll be greatfull if you help me.
>
>
>
>



 
Reply With Quote
 
Victor Bazarov
Guest
Posts: n/a
 
      12-05-2005
Aris wrote:
> Not only a good answer but the way to face this problems
> in the future.
> Gratefull!


Just a note: it would be useful (or maybe simply more pleasant
to whoever gave you that answer), to have quoted the message
you replied to...


 
Reply With Quote
 
Aris
Guest
Posts: n/a
 
      12-07-2005
Hello!
Im trying to implement a queue
using a linked list.
I've made that code
and I expected my Degueue()
function to return the value of the
key of the node I constructed.
But It does not.
In fact it returns "Empty Queue"
what am I doing wrong?


#include <stdlib.h>
#include <stdio.h>

typedef struct Queue * link;
struct Queue
{
link head;
link tail;
link next;
int key;
};

void Enqueue(link Head,link Tail,int data)
{
link ptr=(struct Queue*)malloc(sizeof(struct Queue));
ptr->key=data;
if(Head==0) Head= ptr; else Tail->next=ptr;
Tail=ptr;
}

int Dequeue(link Head,int data)
{
link temp;
if(Head!=0){
data=Head->key;
temp=Head;
Head=Head->next;
}

else
{
printf("Empty Queue\n"); return 0;
}

free(temp);
return data;
}

int main()
{
link head=0;
link tail=0;

Enqueue(head,tail,1);

int x=Dequeue(head,x);
printf("%d\n",x);



return 0;

}



 
Reply With Quote
 
Jeff Flinn
Guest
Posts: n/a
 
      12-07-2005

"Hans Lohninger" <> wrote in message
news:4392ebff$0$28520$ ...
>A good introduction how to handle trees (and other data structures) can be
>found in the free eBook "C++Course". Trees are discussed here:
>
> http://www.vias.org/cppcourse/chap21_01.html
>


Except it's not really C++ is it.

Jeff



 
Reply With Quote
 
Michael Wild
Guest
Posts: n/a
 
      12-07-2005
Jeff Flinn wrote:
> "Hans Lohninger" <> wrote in message
> news:4392ebff$0$28520$ ...
>> A good introduction how to handle trees (and other data structures) can be
>> found in the free eBook "C++Course". Trees are discussed here:
>>
>> http://www.vias.org/cppcourse/chap21_01.html
>>

>
> Except it's not really C++ is it.
>
> Jeff
>
>
>


Since when does c++ have interfaces? (see
http://www.vias.org/cppcourse/chap21_08.html) rather looks like java to
me...

- michael
 
Reply With Quote
 
Ron Natalie
Guest
Posts: n/a
 
      12-08-2005
Aris wrote:
> Hello!
> Im trying to implement a queue
> using a linked list.


You know C++ already provides queues and linked list
as part of the language?

Further the code while syntactcally C++ is pretty
poor C++ design.

> void Enqueue(link Head,link Tail,int data)
> {
> link ptr=(struct Queue*)malloc(sizeof(struct Queue));


> int main()
> {
> link head=0;
> link tail=0;
>
> Enqueue(head,tail,1);


head and tail are still null pointers here. You are passing
by value. All Enqueue does is malloc stuff that gets lost.
 
Reply With Quote
 
 
 
Reply

Thread Tools

Posting Rules
You may not post new threads
You may not post replies
You may not post attachments
You may not edit your posts

BB code is On
Smilies are On
[IMG] code is On
HTML code is Off
Trackbacks are On
Pingbacks are On
Refbacks are Off


Similar Threads
Thread Thread Starter Forum Replies Last Post
Binary tree search algorithm in C++ Bogdan C++ 4 10-19-2010 08:18 PM
Hi, I want to implement a General Tree Data structure (Not Binary Tree ) which have more than 2 sub nodes? sharan C Programming 4 10-30-2007 08:21 PM
Non-recursive algorithm to find the height of a BInary Tree Ravi C Programming 6 08-22-2005 05:21 PM
Need an algorithm for creating an complete binary tree. C-man C++ 2 03-04-2004 09:09 AM
B tree, B+ tree and B* tree Stub C Programming 3 11-12-2003 01:51 PM



Advertisments
 



1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57