162.二叉树:填充每个节点的下一个右侧节点指针(力扣)

代码解决

/*
// Definition for a Node.
class Node {
public:int val;Node* left;Node* right;Node* next;Node() : val(0), left(NULL), right(NULL), next(NULL) {}Node(int _val) : val(_val), left(NULL), right(NULL), next(NULL) {}Node(int _val, Node* _left, Node* _right, Node* _next): val(_val), left(_left), right(_right), next(_next) {}
};
*/class Solution {
public:Node* connect(Node* root) {queue<Node*> que;  // 定义队列用于层次遍历if (root != NULL) que.push(root);  // 如果根节点不为空,则将根节点加入队列while (!que.empty())  // 当队列不为空时,继续处理{int size = que.size();  // 获取当前层的节点数量Node* node;  // 当前处理的节点Node* prenode;  // 前一个处理的节点for (int i = 0; i < size; i++)  // 遍历当前层的每一个节点{if (i == 0)  // 如果是当前层的第一个节点{prenode = que.front();que.pop();node = prenode;}else  // 如果不是当前层的第一个节点{node = que.front();que.pop();prenode->next = node;  // 将前一个节点的 next 指向当前节点prenode = prenode->next;}if (node->left) que.push(node->left);  // 如果该节点有左子节点,将其加入队列if (node->right) que.push(node->right);  // 如果该节点有右子节点,将其加入队列}prenode->next = NULL;  // 当前层的最后一个节点的 next 设为 NULL}return root;  // 返回根节点}
};

测试代码

#include <iostream>
#include <vector>
#include <queue>using namespace std;// Definition for a Node.
class Node {
public:int val;Node* left;Node* right;Node* next;Node() : val(0), left(NULL), right(NULL), next(NULL) {}Node(int _val) : val(_val), left(NULL), right(NULL), next(NULL) {}Node(int _val, Node* _left, Node* _right, Node* _next): val(_val), left(_left), right(_right), next(_next) {}
};class Solution {
public:Node* connect(Node* root) {if (root == NULL) return NULL;  // 如果根节点为空,直接返回 NULLqueue<Node*> que;  // 定义队列用于层次遍历que.push(root);  // 将根节点加入队列while (!que.empty())  // 当队列不为空时,继续处理{int size = que.size();  // 获取当前层的节点数量Node* prenode = NULL;  // 前一个处理的节点,初始化为 NULLfor (int i = 0; i < size; i++)  // 遍历当前层的每一个节点{Node* node = que.front();  // 从队列中取出一个节点que.pop();  // 将该节点从队列中移除if (prenode != NULL) {prenode->next = node;  // 将前一个节点的 next 指向当前节点}prenode = node;  // 更新前一个节点为当前节点if (node->left) que.push(node->left);  // 如果该节点有左子节点,将其加入队列if (node->right) que.push(node->right);  // 如果该节点有右子节点,将其加入队列}prenode->next = NULL;  // 当前层的最后一个节点的 next 设为 NULL}return root;  // 返回根节点}
};// 辅助函数:创建一个测试树
Node* createTestTree() {Node* root = new Node(1);root->left = new Node(2);root->right = new Node(3);root->left->left = new Node(4);root->left->right = new Node(5);root->right->left = new Node(6);root->right->right = new Node(7);return root;
}// 辅助函数:打印树的每一层
void printTreeByLevel(Node* root) {Node* levelStart = root;while (levelStart != NULL) {Node* current = levelStart;levelStart = NULL;while (current != NULL) {cout << current->val << " ";if (!levelStart) {if (current->left) levelStart = current->left;else if (current->right) levelStart = current->right;}current = current->next;}cout << "-> NULL" << endl;}
}int main() {Solution solution;Node* root = createTestTree();root = solution.connect(root);printTreeByLevel(root);  // 打印连接后的树的每一层return 0;
}

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/845546.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

ipv6基础

地址 前缀子网主机位 PI法则3.14 前缀&#xff1a;3个16位 子网&#xff1a;1个16位 接口ID&#xff1a;4个16位 地址分类 未指定地址 ::/128 &#xff0c;类似于0.0.0.0 本地回环地址 ::1/128 &#xff0c;用于本地测试&#xff0c;类似于127.0.0.1 本地链路地址&#x…

利用GNSS IMU集成提高车道级定位精度

准确的定位对于很多不同的事情都是至关重要的。导航系统可以引导我们去某个地方&#xff0c;自动驾驶汽车可以利用这些数据在道路上安全行驶。尽管全球导航卫星系统(GNSS)在定位方面非常出色&#xff0c;但它们可能并不总是提供最准确的车道水平事实。解决这个问题的一个有希望…

如何矢将量数据转换为栅格数据

在我们分析GIS数据时&#xff0c;有时候也可能需要将矢量数据转换为栅格数据来使用&#xff0c;例如&#xff1a;使用AI图像识别技术进行GIS数据分析或导航的时候&#xff01;矢量数据就可能不满足需求了&#xff01; GIS数据转换器-矢量V5.0具有矢量数据转换为栅格数据的功能…

Python魔法之旅-魔法方法(07)

目录 一、概述 1、定义 2、作用 二、应用场景 1、构造和析构 2、操作符重载 3、字符串和表示 4、容器管理 5、可调用对象 6、上下文管理 7、属性访问和描述符 8、迭代器和生成器 9、数值类型 10、复制和序列化 11、自定义元类行为 12、自定义类行为 13、类型检…

linux部署运维1——centos7.9离线安装部署涛思taos2.6时序数据库TDengine

在实际项目开发过程中&#xff0c;并非一直都使用关系型数据库&#xff0c;对于工业互联网类型的项目来说&#xff0c;时序型数据库也是很重要的一种&#xff0c;因此掌握时序数据库的安装配置也是必要的技能&#xff0c;不过对于有关系型数据库使用的开发工作者来说&#xff0…

如何获取SSL证书,消除网站不安全警告

获取SSL证书通常涉及以下几个步骤&#xff1a; 选择证书颁发机构&#xff08;CA&#xff09;&#xff1a; 你需要从受信任的SSL证书颁发机构中选择一个&#xff0c;比如DigiCert、GlobalSign、JoySSL等。部分云服务商如阿里云、腾讯云也提供免费或付费的SSL证书服务。 生成证…

大数据之HIVE,一次HIVESQL执行的过程(四)

在hive中执行如下sql INSERT OVERWRITE TABLE XXX SELECT * from XXX 数据最终是怎么存储到hdfs上的过程 执行的过程当中,打印出如下的日志过程,本质上是一个在MapReduce中进行Shuffle的过程 所以下面就Shuffle的过程进行分析 Shuffle 描述的是数据从 Map 端到 Reduce 端的…

曾巩,散文的艺术与哲思

曾巩&#xff0c;字子固&#xff0c;世称南丰先生&#xff0c;南丰&#xff08;今江西&#xff09;人&#xff0c;生于北宋真宗天禧三年&#xff08;公元1019年&#xff09;&#xff0c;卒于北宋元丰六年&#xff08;公元1083年&#xff09;&#xff0c;享年64岁。他是中国北宋…

数字IC后端项目简历模版

新一年的IC秋招即将来临&#xff0c;应各位读者要求&#xff0c;小编周末抽空编写了一份数字IC后端设计实现项目相关简历模版。本次列出了社区四大IC后端项目的相关要点。大家可以根据自己的实际情况来做适当的修改调整。 截止目前共有4个应届生学过这四个IC后端课程。这几个课…

MySQL学习——查询示例(二)

1 用户定义变量的使用 可以使用MySQL用户定义的变量来存储查询结果&#xff0c;而无需在客户端使用临时变量。以下是一个如何使用用户定义的变量来找到价格最高和最低的商品的示例&#xff1a; mysql> SELECT min_price:MIN(price),max_price:MAX(price) FROM shop;mysql&g…

http协议及httpd安装组成

文章目录 一、http协议http协议通信过程http相关技术网站访问量HTTP工作机制HTTP协议版本HTTP请求访问的完整过程HTTP报文头部响应报文 二、httpd安装组成apache介绍和特点工作模式&#xff08; MPM multi-processing module &#xff09;Http相关文件Http编译安装httpd常见配置…

【日常记录】【JS】前端预览图片的两种方式,Base64预览和blob预览

文章目录 1、前言1、FileReader3、window.URL.createObjectURL4、参考链接 1、前言 一般来说&#xff0c;都是 后端返回给前端图片的url&#xff0c;前端直接把这个值插入到 img 的src 里面即可还有一种情况是前端需要预览一下图片&#xff0c;比如&#xff1a;上传头像按钮&a…

【vuejs】 computed 和 watch 的区别和使用场景说明

1. 计算属性 computed 概述 计算属性 computed 是 Vue.js 中一个非常强大的功能&#xff0c;它允许开发者声明性地描述一个值是如何根据组件中其他数据计算得来的。计算属性是基于它们的依赖进行缓存的&#xff0c;只有当依赖发生变化时&#xff0c;计算属性才会重新计算。这使…

显示器与电脑如何分屏显示?

1.点击电脑屏幕右键--显示设置 2、然后找到屏幕---找到多显示器---选择扩展显示器

OpenAI 推出ChatGPT Edu,为高校定制版本

近日&#xff0c;OpenAI 宣布推出 ChatGPT Edu&#xff0c;这是一款专为高校打造的 ChatGPT 版本&#xff0c;旨在帮助学生、教师、研究人员和校园运营部门以负责任的方式部署和使用 AI。 ChatGPT Edu 由 GPT-4o 提供支持&#xff0c;具备强大的文本和图像推理能力&#xff0c;…

PHP 操作日期各种转换

日期操作 一、根据日期生成日期数组 /*** 根据指定日期生成日期数组* param $start_time 开始时间* param $end_time 结束时间* return array 返回数组结果*/ function createDateArr($start_time, $end_time) {$open_start_time $start_time;$open_end_time $end_ti…

Java18新版本特性!

Java 18引入了多项新特性&#xff0c;主要包括默认UTF-8字符集、简单的Web服务器、栈步进API等。Java 18是Oracle在2022年发布的版本&#xff0c;其旨在通过一系列创新特性来提升开发效率与性能。下面将逐一探讨Java 18的主要新特性以及它们对开发者的具体影响&#xff1a; 默认…

7、css3实现边框不停地跑动效果

效果例图&#xff1a; 1、上html代码&#xff1a; <!DOCTYPE html> <html lang"zh"> <head><meta charset"UTF-8" /><meta name"viewport" content"widthdevice-width, initial-scale1.0" /><meta …

华为Atlas 500 A2小站:如何解决docker的各种报错问题

问题&#xff1a;华为Atlas 500 A2小站&#xff1a;如何解决docker的各种报错问题 在Atlas 500 A2的小站环境搭建中&#xff0c;在使用docker时&#xff0c;如果所有办法都用了&#xff0c;还是报错的话。 如&#xff1a; 报错1&#xff1a;Error response from daemon: Get “…

文明互鉴促发展——2024“国际山地旅游日”主题活动在法国启幕

5月29日&#xff0c;2024“国际山地旅游日”主题活动在法国尼斯市成功举办。中国驻法国使领馆、法国文化旅游部门、地方政府、国际组织、国际山地旅游联盟会员代表、旅游机构、企业、专家、媒体等围绕“文明互鉴的山地旅游”大会主题和“气候变化与山地旅游应对之策”论坛主题展…