博客
关于我
洛谷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/

你可能感兴趣的文章
NetworkX系列教程(11)-graph和其他数据格式转换
查看>>
Networkx读取军械调查-ITN综合传输网络?/读取GML文件
查看>>
Net与Flex入门
查看>>
net包之IPConn
查看>>
NFinal学习笔记 02—NFinalBuild
查看>>
NFS共享文件系统搭建
查看>>
nfs复习
查看>>
NFS网络文件系统
查看>>
ng 指令的自定义、使用
查看>>
nginx + etcd 动态负载均衡实践(二)—— 组件安装
查看>>
nginx + etcd 动态负载均衡实践(四)—— 基于confd实现
查看>>
Nginx + uWSGI + Flask + Vhost
查看>>
Nginx - Header详解
查看>>
Nginx Location配置总结
查看>>
Nginx upstream性能优化
查看>>
Nginx 中解决跨域问题
查看>>
Nginx 动静分离与负载均衡的实现
查看>>
Nginx 反向代理 MinIO 及 ruoyi-vue-pro 配置 MinIO 详解
查看>>
Nginx 反向代理解决跨域问题
查看>>
Nginx 反向代理配置去除前缀
查看>>