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

leetcode_117 填充每个节点的下一个右侧节点指针 II

文章目录

      • 1. 题意
      • 2. 题解
        • 2.1 BFS
        • 2.2 BFS+空间优化
        • 2.3 DFS序+层次记录
      • 3. Ref

1. 题意

在一颗树的同层之间用指针把他们链接起来。

填充每个节点的下一个右侧节点指针 II

2. 题解

2.1 BFS

用一个变量记录下同层最右侧的节点,当遍历到时更新下一层的最右侧节点即可。

class Solution {
public:Node* connect(Node* root) {Node *righMost = root;queue<Node *> q;if (root)q.push(root);while (!q.empty()) {Node *cur = q.front();q.pop();if ( cur -> left) q.push(cur->left);if ( cur->right )q.push(cur->right);if (cur == righMost) {righMost = q.back();}else {cur->next = q.front();}}return root;}
};
2.2 BFS+空间优化

在将下一层的节点放入队列时,其实就可以将他们链接起来了。从而省去了队列的空间,此时保存下每一层的最开始的节点就可以了。

class Solution {
public:void handle(Node *&pre, Node *&nextStart,Node *rt) {if (nullptr == rt) return ;if (!pre) {nextStart = rt;}else {pre->next = rt;}pre = rt;}Node* connect(Node* root) {Node *righMost = root;Node *start = root;Node *nextStart = nullptr;Node *pre = nullptr;for ( ;start; start = nextStart) {nextStart = nullptr;pre = nullptr;for ( ;start;start = start->next) {handle(pre, nextStart, start->left);handle(pre, nextStart, start->right);}}return root;}
};
2.3 DFS序+层次记录

利用先序遍历的永远是从左到又这一特点,用一个pre[depth]数组来记录当前DFS遍历到的该层的左侧节点。当再次遍历到该层时,链接pre[depth]节点到当前节点,并更新。

class Solution {
public:void handle(Node *&pre, Node *&nextStart,Node *rt) {if (nullptr == rt) return ;if (!pre) {nextStart = rt;}else {pre->next = rt;}pre = rt;}void dfs(std::vector<Node*> &pre, Node *root, int depth) {if (nullptr == root)return;int sz = pre.size();if (sz == depth) {pre.push_back(root);}else {pre[depth]->next = root;pre[depth] = root;}dfs(pre, root->left, depth + 1);dfs(pre, root->right, depth + 1);}Node* connect(Node* root) {vector<Node *> pre;dfs(pre, root, 0);return root;}
};

3. Ref

03xf题解

http://www.lryc.cn/news/216569.html

相关文章:

  • 亲测 IDEA Pycharm 全家桶 自动重置免费30天
  • Marp: 将 Markdown 变为 PPT 式样的 VScode 插件
  • 根据正则表达式截取字串符,这个办法打败99%程序员
  • 冬天女儿的羽绒服就选它了,哈哈很喜欢
  • Vim插件配置
  • 函数参数的最佳传递方式与现代C++的规则
  • Asterisk Ubuntu 安装
  • rwkv模型lora微调之accelerate和deepspeed训练加速
  • 分享一下在微信小程序里怎么做一个投票链接
  • v-model语法糖
  • 纷享销客荣获最佳制造业数字营销服务商奖
  • 蓝桥杯每日一题2023.11.3
  • 中国电子云-隐私计算-云原生安全可信计算,物理-硬件-系统-云产品-云平台,数据安全防护
  • PHP服务器端电商API原理及示例讲解(电商接口开发/接入)
  • Spring Cloud应用- Eureka原理、搭建
  • Servlet 设置启动时机(web.xml方式和@WebServlet方式)
  • 一个使用uniapp+vue3+ts+pinia+uview-plus开发小程序的基础模板
  • Kali安装docker
  • Maven第七章:Maven工程最佳实践
  • 【深度学习】【pytorch】对卷积层置零卷积核进行真实剪枝
  • 机器人仿真-gazebo学习笔记(3)URDF和机器人模型
  • lua-resty-request库写入爬虫ip实现数据抓取
  • gitlab Activating and deactivating users
  • linux入门到精通-第五章-动态库和静态库
  • markdown 如何更改字体以及颜色等功能
  • 一次cs上线服务器的练习
  • STM32-高级定时器
  • 三季度业绩狂飙后,贝泰妮将开启集团化运营的“中场战事”?
  • 快速了解:什么是优化问题
  • Unity在Project右键点击物体之后获取到点击物体的名称