| 网站首页 | 业界新闻 | 小组 | 威客 | 人才 | 下载频道 | 博客 | 代码贴 | 在线编程 | 编程论坛
欢迎加入我们,一同切磋技术
用户名:   
 
密 码:  
共有 860 人关注过本帖
标题:教我一下这个递归的执行顺序吧
只看楼主 加入收藏
sainimu78
Rank: 2
等 级:论坛游民
帖 子:57
专家分:26
注 册:2010-1-27
结帖率:100%
收藏
已结贴  问题点数:10 回复次数:2 
教我一下这个递归的执行顺序吧
#include <stdio.h>
typedef struct btnode
{   
    int data;
    struct btnode *lchild;
    struct btnode *rchild;
}BINTNODE, *BINTREE;            /*定义二叉链表指针类型*/

void createbintree(BINTREE *t)
{   
    int a;
     scanf("%d",&a);
     if(a==0)
         *t=NULL;
     else
     {  
         *t=(BINTNODE*)malloc(sizeof(BINTNODE));
     (*t)->data=a;
         createbintree(&(*t)->lchild);
         createbintree(&(*t)->rchild);
     }
}                       /*   不明白这个递归在传入 0 后是怎么执行的
                             教一下 输入 1 2 4 0 0 5 0 0 3 0 6 0 0 (回车) 的执行顺序  
                         像这样  :
                         输入1 (*t)->data=1;
                         输入2 (*(*t)->lchild))->data=2
                         输入4 (*((*t)->lchild)->lchild)->lchild)->data=4
                         可能举例有错 反正就是这意思啦 */

main() /*主函数*/
{   BINTREE t=NULL;
    printf("\nPlease input nodes of BINTREE : ");
    createbintree(&t);
    printf("ok!\n");
   
    getch();
}
搜索更多相关主题的帖子: 顺序 递归 
2010-03-25 09:51
ldg628
Rank: 12Rank: 12Rank: 12
等 级:火箭侠
威 望:3
帖 子:526
专家分:3036
注 册:2009-6-23
收藏
得分:7 
               1
         2          3
      4    5      0   6
    0  0  0  0       0  0
先输入左子树,再输入右子树,一层层的递归,画个图出来一目了然。。。
2010-03-25 10:07
sainimu78
Rank: 2
等 级:论坛游民
帖 子:57
专家分:26
注 册:2010-1-27
收藏
得分:0 
总算理解了



[ 本帖最后由 sainimu78 于 2010-3-25 12:55 编辑 ]
2010-03-25 12:15
快速回复:教我一下这个递归的执行顺序吧
数据加载中...
 
   



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

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