找回密码
 注册
搜索
热搜: 回贴
  • 前程无忧官网首页 有什么好的平台可以
  • 最新的销售平台 互联网营销的平台有哪
  • 制作网页的基本流程 网页制作和网页设
  • 【帝国CMS】输出带序号的列表(数字排
  • 网站建设公司 三一,中联,极东泵车的
  • 织梦 建站 织梦网站模版后台怎么更改
  • 云服务官网 哪些网站有免费的简历模板
  • 如何建网站要什么条件 建网站要用什么
  • 吉林市移动公司电话 吉林省退休人员网
  • 设计类毕业论文 网站设计与实现毕业论
查看: 1903|回复: 7

[求助]我这个递归哪有问题吗?

[复制链接]
发表于 2009-11-3 02:54:45 | 显示全部楼层 |阅读模式 IP:江苏扬州
是个关于二叉树的,这是求二叉树结点的函数,我调用这个函数后,i 怎么都等于1,就是说这个函数求出来的总是说只有1个结点,请教大家我是哪没有写对啊?

void BinaryTree::NodeNumber()
{
int m=0, n;
n=NodeNumber( root, m );
cout<<"该二叉数有"<<n<<"个结点!"<<endl;
}
int BinaryTree::NodeNumber( BinTreeNode *current, int i )
{
if( current!=NULL )
{
i++;
NodeNumber( current->leftChild, i );
NodeNumber( current->rightChild, i );
}
return i;
}
发表于 2009-11-3 02:54:47 | 显示全部楼层 IP:江苏扬州
当然有问题了,你这里传进去的i的值不能作为输出,只是返回了,
NodeNumber( current->leftChild, i );执行完了i的值不会有任何变化
  1. int BinaryTree::NodeNumber( BinTreeNode *current, int& i ) //改为引用
  2. {
  3. if( current!=NULL )
  4. {
  5. i++;
  6. NodeNumber( current->leftChild, i );
  7. NodeNumber( current->rightChild, i );
  8. }
  9. return i;
  10. }
复制代码
回复

使用道具 举报

发表于 2009-11-3 02:54:48 | 显示全部楼层 IP:江苏扬州
对,疏忽了,呵呵
谢谢斑竹的帮助啊~
回复

使用道具 举报

发表于 2009-11-3 02:55:01 | 显示全部楼层 IP:江苏扬州
int m=0, n;
n=NodeNumber( root, m ); //因为你用n来接收了NodeNumber返回的数量,而NodeNumber每次都会返回1
cout<<"该二叉数有"<<n<<"个结点!"<<endl;
回复

使用道具 举报

发表于 2009-11-3 02:55:03 | 显示全部楼层 IP:江苏扬州
恩,好象是这样的,谢谢了~
回复

使用道具 举报

发表于 2009-11-3 02:55:04 | 显示全部楼层 IP:江苏扬州
这样行不行
int BinaryTree::NodeNumber(BinTreeNode *current)
{
if(current==NULL)
return 0;
else
return NodeNumber(current->leftChild)+NodeNumber(current->rightChild)+1;
}
回复

使用道具 举报

发表于 2009-11-3 02:55:05 | 显示全部楼层 IP:江苏扬州
楼上的,你这个我只是想了想,没试验,觉得行得通,而且写得比我好
我还需要多学习学习这种思想啊~还差得远啊,呵呵
回复

使用道具 举报

发表于 2009-11-3 02:55:06 | 显示全部楼层 IP:江苏扬州
学习
回复

使用道具 举报

您需要登录后才可以回帖 登录 | 注册

本版积分规则

QQ|小黑屋|最新主题|手机版|微赢网络技术论坛 ( 苏ICP备08020429号 )

GMT+8, 2024-9-30 11:34 , Processed in 0.227913 second(s), 12 queries , Gzip On, MemCache On.

Powered by Discuz! X3.5

© 2001-2023 Discuz! Team.

快速回复 返回顶部 返回列表