我有这些函数来确定二叉树是否有序。
(假设我们已经实现了treemanagement.c,我已经对其进行了修改以托管整数而不是字符串)
int ordtree(Treeptr p) {
int a, b;
return (p == NULL || fun(p, &a, &b));
}
int fun(Treeptr p, int * ap, int * bp) {
int a, b;
// Is 'p' a leaf?
if (p->left == NULL && p->right == NULL) {
*ap = p->value;
return 1;
}
// Does 'p' have only a left child?
if (p->right == NULL) {
*bp = p->value;
return (fun(p->left, &b, ap) && p->value > b);
}
// Does 'p' have only a right child?
if (p->left == NULL) {
*ap = p->value;
return (fun(p->right, &a, bp) && p->value < a);
}
// 'p' has two children
return (fun(p->right, &a, bp) && fun(p->left, &b, ap));
}
问题是这不适用于完美的树(所有节点都有两个孩子,因为在我的代码中没有在完美树的情况下进行值检查!)。
例如,这棵无序树将被评估为有序树!
4
2 6
1 8 5 7
更大的问题是这来自测试,我不得不使用这个“代码”并填写 GAP。
int fun(Treeptr p, .....GAP A.....)
{
int a, b;
if (p->left == NULL && .....GAP B.....) {
*ap = p->value;
.....GAP C.....
}
if (p->right == NULL) {
*bp = p->value;
return (fun(.....GAP D.....) && p->value > b);
}
if (.....GAP E.....) {
.....GAP F.....
return (fun(p->right, &a, bp) && GAP .....G.....);
}
return (.....GAP H.....);
}
有什么指导吗?