數的同構 檢測程序 爲什麼會花這麼多時間???

#include
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;

}


//有時真的不是最重要的函數和主體出問題了,首先想到的是是不是前面參數是否犯錯,前面是否有缺陷。。。

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

發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章