数的同构 检测程序 为什么会花这么多时间???
来源:互联网 发布: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;
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
- 数的同构 检测程序 为什么会花这么多时间???
- 为什么会有这么多的编程语言
- 为什么会有这么多苦逼的程序员
- 同构数查找程序的优化过程
- 为啥搞电脑的会有这么多空闲时间?
- 为啥搞电脑的会有这么多空闲时间?
- 为什么会有这么多容器呢d
- 同构数的判断
- 数的同构
- 为什么中国的钱这么多
- 为什么这么多的广告呢
- 编程语言思考系列:为什么会有这么多的编程语言?
- Elastic-Job项目源码分析4--为什么会有这么多的service?
- C++实例 同构数 求1000以内的同构数
- IE有这么多问题,为什么用的人这么多
- 10000以内的同构数
- 查找同构数的数量
- 查找同构数的数量
- hdu 5171 fib矩阵快速幂
- Git 教程索引
- BigInteger(HDU1002)和BigDecimal处理
- 冒泡排序
- 滑雪(记忆化)
- 数的同构 检测程序 为什么会花这么多时间???
- 新闻客户端应用项目源码
- OBIEE中JS的使用--在分析列中添加链接
- 当你访问淘宝的时候,发生了什么?
- 控制表单内容字段必填项的一种设计思路
- 一款面试复习应用源码
- 【枚举】Vijos P1496 火柴棒等式 【NOIP2008提高组第二题】
- mysql索引失效的几种情况
- [leetcode] p338 Count Bits