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

【天梯赛练习】L2-035 完全二叉树的层序遍历

  • 后序遍历转层序遍历
  • 后序遍历:左——右——根
  • 层序遍历:数组形式存储的完全二叉树的顺序遍历序列其实就正好是其层序遍历序列。
    • 子树根若是 i d id id,左子树 i d ∗ 2 id*2 id2,右子树 2 ∗ i d + 1 2*id+1 2id+1

所以就是dfs递归找左右子树
注意后序遍历特点,最后才输出根。所以dfs中找完左右子树才记录根。

#include <bits/stdc++.h>
#define forr(i,l,r) for(int i=l;i<=r;i++)
#define reforr(i,l,r) for(int i=r;i>=l;i--)
#define int long long
#define pii pair<int,int>
#define endl '\n'
#define PI 3.14159265
using namespace std;
const int N=35;
int pst[N];
int d,n;
int res[N],cnt=0;
void dfs(int id){if(id>n)return;dfs(id<<1);//左子树dfs(id<<1|1);//右子树res[id]=pst[++cnt];//先到的是最左边的子树// cout<<id<<' '<<cnt<<' '<<res[id]<<endl;
}
void solve(){cin>>n;forr(i,1,n){cin>>pst[i];}dfs(1);forr(i,1,n){cout<<res[i]<<(i==n?'\n':' ');}
}
http://www.xdnf.cn/news/2179.html

相关文章:

  • 阿里云服务器的docker环境安装nacos--实践
  • 开源一体化白板工具Drawnix本地部署打造毫秒级响应的远程协作空间
  • 中介者模式(Mediator Pattern)
  • 目标检测概述
  • LeetCode 2176.统计数组中相等且可以被整除的数对:两层遍历模拟
  • Ubuntu 20.04.6编译安装COMFAST CF-AX90无线网卡驱动
  • Delphi Ini文件对UTF8支持不爽的极简替代方案
  • SpringAI+DeepSeek大模型应用开发——4 对话机器人
  • Qt界面卡住变慢的解决方法
  • 常用UI设计工具及平台概览
  • 【Pandas】pandas DataFrame xs
  • 关于视频的一些算法内容,不包含代码等
  • Java 中 Synchronized如何保证可见性
  • html+js+clickhouse环境搭建
  • Java项目——校园社交网络平台的设计与实现
  • 考研单词笔记 2025.04.17
  • 音视频学习 - ffmpeg 编译与调试
  • 【零基础】基于DeepSeek-R1与Qwen2.5Max的行业洞察自动化平台
  • 记录一次生产中mysql主备延迟问题处理
  • python学习—详解word邮件合并
  • Redis List 的详细介绍
  • 方德桌面操作系统V5.0-G23 vim无法复制粘贴内容
  • Java虚拟机(JVM)平台无关?相关?
  • 在Linux下安装Gitlab
  • 2.深入剖析 Rust+Axum 类型安全路由系统
  • 极狐GitLab GEO 功能介绍
  • DAY 47 leetcode 232--栈与队列.用栈实现队列
  • vue3 element-plus中的国际化在onMounted中的写法
  • docker Windows 存放位置
  • 【web考试系统的设计】