| 网站首页 | 业界新闻 | 小组 | 威客 | 人才 | 下载频道 | 博客 | 代码贴 | 在线编程 | 编程论坛
欢迎加入我们,一同切磋技术
用户名:   
 
密 码:  
共有 2237 人关注过本帖
标题:判断一棵二叉树是否是BST问题
只看楼主 加入收藏
hcs_xiaohan
Rank: 2
等 级:论坛游民
帖 子:40
专家分:23
注 册:2016-7-4
结帖率:91.67%
收藏
已结贴  问题点数:20 回复次数:1 
判断一棵二叉树是否是BST问题
代码如下:

bool IsBST(TreeNode* root) {
    if (!root) return true;
    return root->data >= root->lchild->data && root->data <= root->rchild->data && IsBST(root->lchild)
        && IsBST(root->rchild);
}

请问这个函数到底有什么问题,为什么每次运行程序就会崩溃。
搜索更多相关主题的帖子: 运行程序 return 二叉树 
2016-09-28 12:36
书生牛犊
Rank: 14Rank: 14Rank: 14Rank: 14
来 自:星夜征程
等 级:贵宾
威 望:10
帖 子:1101
专家分:5265
注 册:2015-10-27
收藏
得分:20 
1.  root->data >=root->lchild->data是导致必然崩溃的原因。因为root->lchild 在某些时刻会是NULL。此时,程序执行到NULL->data,,就炸了。

你给的代码不完整。我没办法做测试,看不到具体是怎么崩溃的。我所讲的只是导致崩溃的其中一个原因,不一定是全部。下次请辅助完整的代码上来。最好放到代码框里,格式化处理地美观点。这样别人会更乐意复制、调试。才能帮到你。

第二你的这个代码简短精悍,看着像是个老手才写得出来的。但不应该对指针这么不熟悉才是啊



φ(゜▽゜*)♪
2016-09-29 17:27
快速回复:判断一棵二叉树是否是BST问题
数据加载中...
 
   



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

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