news 2026/5/25 13:38:25

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

作者头像

张小明

前端开发工程师

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/5/25 9:50:24

【开题答辩全过程】以 基于SSM框架的餐厅点餐系统的设计与实现为例,包含答辩的问题和答案

个人简介一名14年经验的资深毕设内行人&#xff0c;语言擅长Java、php、微信小程序、Python、Golang、安卓Android等开发项目包括大数据、深度学习、网站、小程序、安卓、算法。平常会做一些项目定制化开发、代码讲解、答辩教学、文档编写、也懂一些降重方面的技巧。感谢大家的…

作者头像 李华
网站建设 2026/5/26 6:54:02

豆包 AI 手机登录微信被「踢下线」,原因为何?端侧 AI 与头部应用的生态兼容上存在哪些挑战?

2025年12月&#xff0c;豆包 AI 手机的发布成为了科技行业的热门话题。这款手机的最大亮点在于其情感智能系统&#xff0c;能够通过面部识别、语音分析等方式实时感知用户的情绪&#xff0c;并根据情感变化提供个性化的互动和服务。然而&#xff0c;在迎来巨大关注的同时&#…

作者头像 李华
网站建设 2026/5/26 6:54:12

【第56套】很综合,值得练手!

写在前面车门焊死&#xff0c;考研将至&#xff0c;准备冲刺&#xff01;我将持续为大家更新25最新真题解析&#xff01;学得快的同学可以和我一起&#xff0c;全力冲刺&#xff5e;注意&#xff0c;目前我只发布最新年份的真题&#xff0c;其他年份的真题&#xff0c;一个是很…

作者头像 李华