您的位置:首页 > 编程语言

数的同构 检测程序 为什么会花这么多时间???

2016-03-23 00:33 302 查看
#include <iostream>

using namespace std;

typedef int TreePtr;

typedef char TreeElemType;

const int null = -1;

const int MAXLEN = 10;

struct TreeNode

{
TreeElemType data;
TreePtr l;
TreePtr r;

};

TreeNode Tree1[MAXLEN];

TreeNode Tree2[MAXLEN];

int BuildTree(TreeNode *t)

{
int n,i, j;
char  l, r;
int root = null;
int b[MAXLEN];
for (i = 0; i < MAXLEN; i++)
b[i] = 0;
cin >> n;
for (j = 0; j < n; j++)
{
cin >> t[j].data >> l >> r;
t[j].l = l == '-' ? null : l - '0';//  写程序决不能急躁,不然肯定有纰漏,忘记类型。!
t[j].r = r == '-' ? null : r - '0';
if (l != '-')
b[l - '0'] = 1;
if (r != '-')
b[r - '0'] = 1;
}
for (i = 0; i < n; i++)//for 循环的break要特别注意,有特别是多重循环。
if (!b[i])
root = i;
return root;

}

bool IsSameTree(int r1, int r2)

{
if (r1 == null&&r2 == null)
return 1;
if (r1 == null&&r2 != null || r1 != null&&r2 == null)
return 0;
if (Tree1[r1].data != Tree2[r2].data)
return 0;
return
(IsSameTree(Tree1[r1].l, Tree2[r2].l)
&& IsSameTree(Tree1[r1].r, Tree2[r2].r)) + (IsSameTree(Tree1[r1].l, Tree2[r2].r)
&& IsSameTree(Tree1[r1].r, Tree2[r2].l));

}
//运算符的优先级一定要真正记住,熟练

int main()

{
int r1, r2;
r1 = BuildTree(Tree1);
r2 = BuildTree(Tree2);
if (IsSameTree(r1, r2))
cout << "Yes" << endl;
else
cout << "No" << endl;
return 0;
}

//有时真的不是最重要的函数和主体出问题了,首先想到的是是不是前面参数是否犯错,前面是否有缺陷。。。

不能急躁,不能急躁,不能急躁。
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签:  编程