标题:用非递归方法创建一个二叉树,再用递归方法先中后序遍历,然后用非递归层次 ...
只看楼主
xiaoyou116
Rank: 1
等 级:新手上路
帖 子:2
专家分:0
注 册:2005-12-8
 问题点数:0 回复次数:4 
用非递归方法创建一个二叉树,再用递归方法先中后序遍历,然后用非递归层次遍历
用非递归方法创建一个二叉树,再用递归方法先中后序遍历,然后用非递归层次遍历,这个程序怎么写啊,请各位高手帮帮忙好吗?
搜索更多相关主题的帖子: 遍历 递归层次 递归方法 二叉树 非递归 
2005-12-08 16:51
卡拉是只猫
Rank: 1
等 级:新手上路
威 望:1
帖 子:129
专家分:0
注 册:2005-12-7
得分:0 
[CODE]
#include<stdlib.h>
struct tree //声明树的结构
{
struct tree *left;
int data;
struct tree *right;
};
typedef struct tree treenode;
type treenode *b_tree; //声明二叉树链表
//插入二叉树的节点
b_tree insert_node(b_tree root,int node)
{
b_tree newnode;
b_tree currentnode;
b_tree parentnode;

newnode=(b_tree)malloc(sizeof(treenode)); //建立新节点的内存空间
newnode->data=node;
newnode->right=NULL;
newnode->left=NULL;
if(root=NULL)
return newnode;
else
{ currentnode=root;
while(currentnode!=NULL)
{ parentnode=currentnode;
if( currentnode->data>node)
currentnode=currentnode->left;
else currentnode=currentnode->right;
}
if(parentnode->data>node)
parentnode->left=newnode;
else parentnode->right=newnode;
}
return root;
}
// 建立二叉树
b_tree create_btree(int *data,int len)
{
b_tree root=NULL;
int i;
for(i=0;i<len;i++)
root=insert_node(root,data[i]);
return root;
}

//二叉树中序遍历
void inorder(b_tree point)
{
if(point!=NULL)
{
inorder(point->left);
printf("%d",point->data);
inorder(point->right);
}
}

//主程序
void main( )
{
b_tree root=NULL;
int i,index;
int value;
int nodelist[20];
printf("\n pleaase input the elements of binary tree(exit for 0 ):\n");
index=0;

//读取数值存到数组中
scanf("%d",&value);

while(value!=0)
{
nodelist[index]=value];
index=index+1;
scanf("%d",&value);
}
//建立二叉树
root=create_btree(nodelist,index);

//中序遍历二叉树
printf("\nThe inorder traversal result is :");
inorder(root);
printf("\n");
}
[/CODE]


搞不懂就问人,搞得懂就答人。
2005-12-10 13:24
沉默的羔羊1013
Rank: 1
等 级:新手上路
帖 子:72
专家分:0
注 册:2005-12-10
得分:0 

include <stdlib.h>
#define Null 0

struct tree_node \\声明二差树节点结构
{
int data;
struct tree_node *left;
struct tree_node *right;
};

typedef struct tree_node tree_list;
typedef tree_list *btree;

struct s_node \\声明堆栈结构
{
btree data;
struct s_node *next;
};

typedef struct s_node s_list;
typedef s_list *link;

btree insert_btree(btree root,int node) \\插入二叉树节点
{
btree new,parent,current;
new=(btree)malloc(sizeof(tree_list));
new->data=node;
new->left=Null;
new->right=Null;
if(root==Null)
{
return new;
}
else
{
current=root;
while(current!=Null)
{
parent=current;
if(new->data<current->data)
{
current=current->left;
}
else
{
current=current->right;
}
}
if(new->data<parent->data)
{
parent->left=new;
}
else
{
parent->right=new;
}
return root;
}
}

btree create_btree(int *nodlist,int len) \\建立二叉树
{
btree root=Null;
int i;
for(i=0;i<len;i++)
{
root=insert_btree(root,nodlist[i]);
}
return root;
}

link push(link stack,btree value) \\入栈函数
{
link new;
new=(link)malloc(sizeof(s_list));
new->data=value;
new->next=Null;
if(stack==Null)
{
stack=new;
return stack;
}
else
{
new->next=stack;
stack=new;
return stack;
}
}

link pop(link stack,btree *value) \\出栈函数
{
link pointer;
pointer=stack;
if(pointer==Null)
{
return Null;
}
else
{
stack=stack->next;
*value=pointer->data;
free(pointer);
return stack;
}
}

void search_btree(btree root) \\非递归层次遍历
{
link stack=Null;
btree value1;
int i=0;
value1=root;
printf("%d\n",value1->data);
while(stack!=Null||value1->left!=Null||value1->right!=Null)
{
if(value1==Null)
{
stack=pop(stack,&value1);
printf("%d\n",value1->data);
}
else if(value1->left!=Null&&value1->right!=Null)
{
printf("%d\n",value1->right->data);
stack=push(stack,value1->left);
value1=value1->right;
}
else if(value1->left==Null&&value1->right==Null)
{
stack=pop(stack,&value1);
if(value1!=Null)
{
printf("%d\n",value1->data);
}
}
else if(value1->left!=Null&&value1->right==Null)
{
stack=push(stack,value1->left);
value1=Null;
}
else if(value1->left==Null&&value1->right!=Null)
{
printf("%d\n",value1->right->data);
value1=value1->right;
}
}
}

void inorder_btree(btree root) \\递归法中序遍历
{
if(root!=Null)
{
inorder_btree(root->left);
printf("%d\n",root->data);
inorder_btree(root->right);
}
}

main()
{
int i,index,data;
int nodlist[16]={6,9,7,4,5,2,1,8,12};
btree root,root1;
link stack;
index=9;
root=create_btree(nodlist,index);
search_btree(root);
getch();
}

2005-12-11 01:31
沉默的羔羊1013
Rank: 1
等 级:新手上路
帖 子:72
专家分:0
注 册:2005-12-10
得分:0 

void invertorder_btree(btree root) \\递归法后序遍历
{
if(root!=Null)
{
invertorder_btree(root->left);
invertorder_btree(root->right);
printf("%d\n",root->data);
}
}
这个非递归层次遍历还挺难写,靠,想了好一阵才写出来。。。

2005-12-11 01:34
xiaoyou116
Rank: 1
等 级:新手上路
帖 子:2
专家分:0
注 册:2005-12-8
得分:0 

在下对列位的景仰犹如滔滔江水,连绵不绝,俩字儿:谢谢

2005-12-21 11:18



参与讨论请移步原网站贴子:https://bbs.bccn.net/thread-37325-1-1.html




关于我们 | 广告合作 | 编程中国 | 清除Cookies | TOP | 手机版

编程中国 版权所有,并保留所有权利。
Powered by Discuz, Processed in 0.238307 second(s), 7 queries.
Copyright©2004-2025, BCCN.NET, All Rights Reserved