怎么使用二叉树
发表于:2025-11-13 作者:千家信息网编辑
千家信息网最后更新 2025年11月13日,这篇文章主要介绍"怎么使用二叉树",在日常操作中,相信很多人在怎么使用二叉树问题上存在疑惑,小编查阅了各式资料,整理出简单好用的操作方法,希望对大家解答"怎么使用二叉树"的疑惑有所帮助!接下来,请跟着
千家信息网最后更新 2025年11月13日怎么使用二叉树
这篇文章主要介绍"怎么使用二叉树",在日常操作中,相信很多人在怎么使用二叉树问题上存在疑惑,小编查阅了各式资料,整理出简单好用的操作方法,希望对大家解答"怎么使用二叉树"的疑惑有所帮助!接下来,请跟着小编一起来学习吧!
「以下以前序遍历为例:」
「确定递归函数的参数和返回值」:因为要打印出前序遍历节点的数值,所以参数里需要传入vector在放节点的数值,除了这一点就不需要在处理什么数据了也不需要有返回值,所以递归函数返回类型就是void,代码如下:
void traversal(TreeNode* cur, vector& vec)
「确定终止条件」:在递归的过程中,如何算是递归结束了呢,当然是当前遍历的节点是空了,那么本层递归就要要结束了,所以如果当前遍历的这个节点是空,就直接return,代码如下:
if (cur == NULL) return;
「确定单层递归的逻辑」:前序遍历是中左右的循序,所以在单层递归的逻辑,是要先取中节点的数值,代码如下:
vec.push_back(cur->val); // 中 traversal(cur->left, vec); // 左 traversal(cur->right, vec); // 右
单层递归的逻辑就是按照中左右的顺序来处理的,这样二叉树的前序遍历,基本就写完了,在看一下完整代码:
前序遍历:
class Solution { public: void traversal(TreeNode* cur, vector& vec) { if (cur == NULL) return; vec.push_back(cur->val); // 中 traversal(cur->left, vec); // 左 traversal(cur->right, vec); // 右 } vector preorderTraversal(TreeNode* root) { vector result; traversal(root, result); return result; } }; 那么前序遍历写出来之后,中序和后序遍历就不难理解了,代码如下:
中序遍历:
void traversal(TreeNode* cur, vector& vec) { if (cur == NULL) return; traversal(cur->left, vec); // 左 vec.push_back(cur->val); // 中 traversal(cur->right, vec); // 右 }
后序遍历:
void traversal(TreeNode* cur, vector& vec) { if (cur == NULL) return; traversal(cur->left, vec); // 左 traversal(cur->right, vec); // 右 vec.push_back(cur->val); // 中 }
此时大家可以做一做leetcode上三道题目,分别是:
144.二叉树的前序遍历
145.二叉树的后序遍历
94.二叉树的中序遍历
到此,关于"怎么使用二叉树"的学习就结束了,希望能够解决大家的疑惑。理论与实践的搭配能更好的帮助大家学习,快去试试吧!若想继续学习更多相关知识,请继续关注网站,小编会继续努力为大家带来更多实用的文章!
递归
代码
节点
学习
单层
数值
逻辑
中左
函数
参数
就是
更多
处理
帮助
实用
接下来
完了
数据
文章
方法
数据库的安全要保护哪些东西
数据库安全各自的含义是什么
生产安全数据库录入
数据库的安全性及管理
数据库安全策略包含哪些
海淀数据库安全审计系统
建立农村房屋安全信息数据库
易用的数据库客户端支持安全管理
连接数据库失败ssl安全错误
数据库的锁怎样保障安全
铜陵互联网视频系统服务器
ibm服务器改电源
公司网络安全工作的难点
江苏管理软件开发记录
甘肃联想服务器虚拟化多少钱
网络技术员去哪里找
联想服务器磁盘管理工具
如何远程备份数据库
网络安全应急处置工作办法
芜湖电信首选DNS服务器地址
软件开发及上线流程图
计算机网络安全原理 百度网盘
四川数据库外泌体价格
最关键的是网络技术水平
怎么获取服务器管理员密码
贵州超级计算套料软件开发商
杭州知识产权融资服务数据库
安全风险数据库 作业活动2
怎样备份服务器数据
海军版军营网络安全
cs600b数据库文件
软件开发项目职务有哪些
软件开发等税收优惠
我的世界服务器管理员教程
收银机服务器地址删除了怎么恢复
出境软件开发
网络安全周活动工作总结
数据库的表格能导出来吗
10个常用的网络安全协议
如何连接数据库的数据表