博客
关于我
洛谷P1377树的序
阅读量:340 次
发布时间:2019-03-04

本文共 2625 字,大约阅读时间需要 8 分钟。

洛谷P1377 树的序 思路

树的结构设计是解决这道题的关键。根据题意,我们需要用4个数组来表示一棵树,其中:

  • 一个数组保存树的值
  • 一个数组保存左孩子指针
  • 一个数组保存右孩子指针
  • 一个数组保存父节点指针

通过这种设计,我们可以用两个方向的指针来表示树的左、右孩子,从而实现对树的遍历。

洛谷P1377 树的序 代码

#include 
#include
#include
using namespace std;int a[100010][4];void DFS(int x) { if (x == 0) return; cout << x << " "; if (a[x][2]) DFS(a[x][2]); if (a[x][3]) DFS(a[x][3]); return;}int main() { ios::sync_with_stdio(false); int i, n, len = 0, tem; memset(a, 0, sizeof(a)); for (cin >> n, i = 1; i <= n; ++i) { cin >> tem; a[tem][0] = i; } for (i = 1; i <= n; ++i) { for (tem = len; tem && a[a[tem][1]][0] > a[i][0]; --tem) { if (tem) a[a[tem][1]][3] = i; } if (tem) a[a[tem][1]][3] = i; if (tem) a[a[tem][1]][3] = i; }}

树的序 思路

树的结构设计是解决这道题的关键。根据题意,我们需要用4个数组来表示一棵树,其中:

  • 一个数组保存树的值
  • 一个数组保存左孩子指针
  • 一个数组保存右孩子指针
  • 一个数组保存父节点指针

通过这种设计,我们可以用两个方向的指针来表示树的左、右孩子,从而实现对树的遍历。

树的序 代码

#include 
#include
#include
using namespace std;int a[100010][4];void DFS(int x) { if (x == 0) return; if (a[x][2]) { cout << a[x][2]; if (a[a[x][2]][2]) { cout << " "; if (a[a[x][2]][2]) { cout << a[a[x][2]][2]; } } } if (a[x][3]) { cout << " "; if (a[a[x][3]][2]) { cout << a[a[x][3]][2]; } } return;}int main() { ios::sync_with_stdio(false); int i, n, len = 0, tem; memset(a, 0, sizeof(a)); for (cin >> n, i = 1; i <= n; ++i) { cin >> tem; a[tem][0] = i; } for (i = 1; i <= n; ++i) { for (tem = len; tem && a[a[tem][1]][0] > a[i][0]; --tem) { if (tem) a[a[tem][1]][3] = i; } if (tem) a[a[tem][1]][3] = i; if (tem) a[a[tem][1]][3] = i; }}

树的序 思路

树的结构设计是解决这道题的关键。根据题意,我们需要用4个数组来表示一棵树,其中:

  • 一个数组保存树的值
  • 一个数组保存左孩子指针
  • 一个数组保存右孩子指针
  • 一个数组保存父节点指针

通过这种设计,我们可以用两个方向的指针来表示树的左、右孩子,从而实现对树的遍历。

树的序 代码

#include 
#include
#include
using namespace std;int a[100010][4];void DFS(int x) { if (x == 0) return; cout << x << " "; if (a[x][2]) { DFS(a[x][2]); } if (a[x][3]) { DFS(a[x][3]); } return;}int main() { ios::sync_with_stdio(false); int i, n, len = 0, tem; memset(a, 0, sizeof(a)); for (cin >> n, i = 1; i <= n; ++i) { cin >> tem; a[tem][0] = i; } for (i = 1; i <= n; ++i) { for (tem = len; tem && a[a[tem][1]][0] > a[i][0]; --tem) { if (tem) a[a[tem][1]][3] = i; } if (tem) a[a[tem][1]][3] = i; if (tem) a[a[tem][1]][3] = i; }}

转载地址:http://wrze.baihongyu.com/

你可能感兴趣的文章
Objective-C实现area under curve曲线下面积算法(附完整源码)
查看>>
Objective-C实现arithmetic算术算法(附完整源码)
查看>>
Objective-C实现armstrong numbers阿姆斯壮数算法(附完整源码)
查看>>
Objective-C实现articulation-points(关键点)(割点)算法(附完整源码)
查看>>
Objective-C实现atoi函数功能(附完整源码)
查看>>
Objective-C实现average absolute deviation平均绝对偏差算法(附完整源码)
查看>>
Objective-C实现average mean平均数算法(附完整源码)
查看>>
Objective-C实现average median平均中位数算法(附完整源码)
查看>>
Objective-C实现average mode平均模式算法(附完整源码)
查看>>
Objective-C实现avl 树算法(附完整源码)
查看>>
Objective-C实现AvlTree树算法(附完整源码)
查看>>
Objective-C实现backtracking Jump Game回溯跳跃游戏算法(附完整源码)
查看>>
Objective-C实现BACKTRACKING 方法查找集合的幂集算法(附完整源码)
查看>>
Objective-C实现bailey borwein plouffe算法(附完整源码)
查看>>
Objective-C实现balanced parentheses平衡括号表达式算法(附完整源码)
查看>>
Objective-C实现base64加密和base64解密算法(附完整源码)
查看>>
Objective-C实现base64加解密(附完整源码)
查看>>
Objective-C实现base64编码 (附完整源码)
查看>>
Objective-C实现base85 编码算法(附完整源码)
查看>>
Objective-C实现basic graphs基本图算法(附完整源码)
查看>>