当前位置: 首页 > news >正文

站开发技术培训呼市网站制作

站开发技术培训,呼市网站制作,怎么做网站框架,wordpress 暂无评论【题目来源】https://www.luogu.com.cn/problem/B3642【题目描述】 有一个 n(n≤10^6) 个结点的二叉树。给出每个结点的两个子结点编号(均不超过 n),建立一棵二叉树(根结点的编号为 1),如果是叶子结点&…

【题目来源】
https://www.luogu.com.cn/problem/B3642

【题目描述】
有一个 n(n≤10^6) 个结点的二叉树。给出每个结点的两个子结点编号(均不超过 n),建立一棵二叉树(
根结点的编号为 1),如果是叶子结点,则输入 0 0。
建好树这棵二叉树之后,依次求出它的前序、中序、后序列遍历。

【输入格式】
第一行一个整数 n,表示结点数。
之后 n 行,第 i 行两个整数 l、r,分别表示结点 i 的左右子结点编号。若 l=0 则表示无左子结点,r=0 同理。

【输出格式】
输出三行,每行 n 个数字,用空格隔开。
第一行是这个二叉树的前序遍历。
第二行是这个二叉树的中序遍历。
第三行是这个二叉树的后序遍历。

【输入样例】
7
2 7
4 0
0 0
0 3
0 0
0 5
6 0

【输出样例】
1 2 4 3 7 6 5
4 3 2 1 6 5 7
3 4 2 5 6 7 1

【算法分析】
● 结构体方法,简单易懂。
● 链式前向星方法,复杂烧脑。
链式前向星:https://blog.csdn.net/hnjzsyjyj/article/details/126474608

【算法代码一:结构体方法】

#include <bits/stdc++.h>
using namespace std;const int maxn=1e6+5;struct Tree {int le,ri;
} tr[maxn];void pre(int x) {cout<<x<<" ";int le=tr[x].le;int ri=tr[x].ri;if(le) pre(le);if(ri) pre(ri);
}void in(int x) {int le=tr[x].le;int ri=tr[x].ri;if(le) in(le);cout<<x<<" ";if(ri) in(ri);
}void post(int x) {int le=tr[x].le;int ri=tr[x].ri;if(le) post(le);if(ri) post(ri);cout<<x<<" ";
}int main() {int head=1;int n;cin>>n;for(int i=1; i<=n; i++) {cin>>tr[i].le>>tr[i].ri;}pre(head),cout<<endl;in(head),cout<<endl;post(head),cout<<endl;return 0;
}/*
in:
7
2 7
4 0
0 0
0 3
0 0
0 5
6 0out:
1 2 4 3 7 6 5
4 3 2 1 6 5 7
3 4 2 5 6 7 1
*/


【算法代码二:链式前向星方法】

#include <bits/stdc++.h>
using namespace std;const int maxn=1e6+5;
const int maxm=maxn<<1;
int h[maxn],e[maxm],ne[maxm],idx;void add(int a,int b) {e[idx]=b,ne[idx]=h[a],h[a]=idx++;
}void pre(int u) {cout<<u<<" ";for(int i=h[u]; i!=-1; i=ne[i]) {int j=e[i];if(j!=0) pre(j);}
}void in(int u) {int v1=0, v2=1;for(int i=h[u]; i!=-1; i=ne[i]) {v1++;int j=e[i];if(j==0) continue;if(v1==2) cout<<u<<" ", v2=0;in(j);}if(v2) cout<<u<<" ";
}void post(int u) {for(int i=h[u]; i!=-1; i=ne[i]) {int j=e[i];if(j!=0) post(j);}cout<<u<<" ";
}int main() {memset(h,-1,sizeof h);int head=1;int n;cin>>n;for(int i=1; i<=n; i++) {int le,ri;cin>>le>>ri;//Because it's head insertion,//so insert the right side firstadd(i,ri);add(i,le);}pre(head),cout<<endl;in(head),cout<<endl;post(head),cout<<endl;return 0;
}/*
in:
7
2 7
4 0
0 0
0 3
0 0
0 5
6 0out:
1 2 4 3 7 6 5
4 3 2 1 6 5 7
3 4 2 5 6 7 1
*/




【参考文献】
https://blog.csdn.net/qq_39456436/article/details/138681903
https://blog.csdn.net/hnjzsyjyj/article/details/127290036






 

http://www.yayakq.cn/news/627118/

相关文章:

  • 泰州网站制作方案定制如何注销公司
  • 刷单类网站开发网站主机和空间
  • 网站被k还能不能在百度做推广最新网页游戏公益服
  • 做网站需要人在看吗iis新建网站无法浏览
  • 郑州区块链数字钱包网站开发公司桐柏网站建设
  • 江西医疗网站建设做商城网站需要什么条件
  • 领动做的企业网站怎么样如何常看wordpress默认编辑器
  • 公司网站格式网站建设必须注意的事项
  • wordpress 单页面 外贸外贸网站怎么做seo
  • 做养生网站怎么赚钱个人网站做联盟营销
  • 百度网盘官方网站广州公司网站设计
  • 二手车做网站的目的设计品牌网站公司
  • 站长工具alexa排名无代码开发软件
  • 潍坊个人做网站网络设计报告怎么写
  • 做枸杞的网站石家庄logo设计公司
  • 网站开发外包售后维护合同西安旅游网站开发
  • 青岛网站厉害的公司石岩做网站哪家好
  • 网站做支付宝花呗分期做电影网站服务器需求
  • 网站开发的环境做网站设计提成赚钱吗
  • 小吃加盟网站大全wordpress的极限访问量
  • 一小时学会网站建设西安公司网站建设哪家专业
  • 有什么办法做自己的网站vs做网站怎么放视频
  • 做网站必须要dreamever建设银行网站查询密码
  • 免费的行情网站app软件百度网盘官方网站
  • 苍南县龙港哪里有做网站合肥网站推广优化
  • 网站备案行业东莞东城招聘网最新招聘
  • 生活分类网站建设一流的五屏网站建设
  • 成都网站搜索优化网站建设招标评分标准
  • 大理网站制作域名解析后多久打开网站
  • 英文网站建设szjijie重庆安全员c证在哪里报名