news 2026/3/4 18:31:46

程序综合实践第十二周-二叉树

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
程序综合实践第十二周-二叉树

1、二叉树求高度

#include<bits/stdc++.h> using namespace std; int n; const int N=105; struct node{ int left; int right; int data; }a[N]; int dfs(int r){ if(r==0)return 0; int h1=dfs(a[r].left); int h2=dfs(a[r].right); return max(h1,h2)+1; } int main(){ cin>>n; for(int i=1;i<=n;i++){ cin>>a[i].data>>a[i].left>>a[i].right; } cout<<dfs(1); return 0; }

2、二叉树非叶子

#include<bits/stdc++.h> using namespace std; int n; const int N=105; struct node{ int data; int left; int right; }a[N]; void xianxu(int idx){ if(idx==0)return; cout<<a[idx-1].data<<" "; xianxu(a[idx-1].left); xianxu(a[idx-1].right); } int main(){ cin>>n; for(int i=0;i<n;i++){ cin>>a[i].data>>a[i].left>>a[i].right; } for(int i=0;i<n;i++){ if(a[i].left!=0&&a[i].right!=0){ a[i].data+=1; } } xianxu(1); cout<<endl; return 0; }

3、钻石收藏家

#include<bits/stdc++.h> using namespace std; const int N=1e5+5; int a[N]; int main(){ int n,k; cin>>n>>k; for(int i=0;i<n;i++){ cin>>a[i]; } sort(a,a+n); int max_cnt=0; int left=0; for(int right=0;right<n;right++){ while(a[right]-a[left]>k){ left++; } max_cnt=max(max_cnt,right-left+1); } cout<<max_cnt<<endl; return 0; }

4、牛奶桶Milk Pails

#include<bits/stdc++.h> using namespace std; int main(){ int x,y,m; cin>>x>>y>>m; int max_cnt=0; for(int i=0;i*x<=m;i++){ for(int j=0;i*x+j*y<=m;j++){ int t=i*x+j*y; max_cnt=max(max_cnt,t); } } cout<<max_cnt<<endl; return 0; }

5、我在哪?(Where am I?)

#include<bits/stdc++.h> using namespace std; bool check(int n,char a[],int k){ for(int i=1;i<=n-k+1;i++){ for(int j=i+1;j<=n-k+1;j++){ bool f=true; for(int l=0;l<k;l++){ if(a[i+l]!=a[j+l]){ f=false; break; } } if(f){ return false; } } } return true; } int main(){ int n; char a[105]; cin>>n; for(int i=1;i<=n;i++){ cin>>a[i]; } for(int k=1;k<=n;k++){ if(check(n,a,k)){ cout<<k<<endl; return 0; } } cout<<n<<endl; return 0; }

6、FBI树

#include <bits/stdc++.h> using namespace std; int a[2048+10]; int len; void buildTree(int root) { if(root>=len)return; buildTree(2*root); buildTree(2*root+1); if(a[2*root]==1&&a[2*root+1]==1)a[root]= 1; else if(a[2*root]==0&&a[2*root+1]==0)a[root]=0; else a[root]=2; } void dfsTree(int root) { if(root>=2*len)return; dfsTree(2*root); dfsTree(2*root+1); if (a[root]==1)cout<<"I"; else if(a[root]==0)cout<<"B"; else cout<<"F"; } int main() { int n; string str; cin>>n; cin>>str; len=1<<n; for(int i=len;i<=2*len-1;i++){ a[i]=str[i-len]-'0'; } buildTree(1); dfsTree(1); return 0; }

7、先序排列(后中求先)

#include<bits/stdc++.h> using namespace std; void xianxu(string data,string order){ if(data.empty()||order.empty())return; char r=order[order.size()-1]; cout<<r; int pos=data.find(r); string left=data.substr(0,pos); string right=data.substr(pos+1); int left_len=left.size(); string left_v=order.substr(0,left_len); string right_v=order.substr(left_len,order.size()-left_len-1); xianxu(left,left_v); xianxu(right,right_v); } int main(){ string idx,post; cin>>idx>>post; xianxu(idx,post); cout<<endl; return 0; }
版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/2/28 3:20:40

面试百问:Redis常见的故障以及发生场景

作为一个测试同学&#xff0c;被测系统架构中有使用到redis吗&#xff1f;对redis常见的故障有了解吗&#xff1f;又是如何进行测试的呢&#xff1f; 针对常见的redis面试问题&#xff0c;怎样才算一个高质量的回答呢&#xff0c;回答思路一般包括 问题的类型是什么&#xff…

作者头像 李华
网站建设 2026/2/27 2:13:06

食品X光检测机市场格局与关键厂商分析

于食品生产这个行业里头&#xff0c;异物检测可是保障产品安全以及维护品牌声誉极为关键重要的环节&#xff0c;食品X光机身为核心检测设备&#xff0c;借由X射线穿透的原理&#xff0c;能够高效地识别产品里头混入的像金属、玻璃、陶瓷、石子甚至某些硬质塑料等各种各样的异物…

作者头像 李华
网站建设 2026/3/4 4:57:00

模型预测控制(MPC):混动汽车能量管理的革新之道

模型预测控制&#xff08;MPC&#xff09;在混合动力汽车能量管理策略开发上的运用。 利用车速预测模型&#xff08;BP或者RBF神经网络&#xff0c;预测模型资料也有发在其他链接&#xff09;根据预测的信息对车辆进行优化控制&#xff0c;可以对混动汽车的能量管理具有一定的参…

作者头像 李华
网站建设 2026/3/2 12:40:33

UML,HTML,XML,YAML,JSON的关系概述

探讨的这五种语言/格式各有不同的设计目的和应用领域&#xff0c;它们之间的关系可以从数据表示、结构化标记、序列化、建模等角度来分析。下面将分别介绍它们&#xff0c;然后阐述它们之间的关系&#xff0c;并举例说明。 一、概述 UML&#xff08;统一建模语言&#xff09;&…

作者头像 李华