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

来源:互联网 发布:unity5.3.4f1破解mac 编辑:程序博客网 时间:2024/04/25 13:59
#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;

}


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

不能急躁,不能急躁,不能急躁。

0 0
原创粉丝点击