博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
[Leetcode Week15]Populating Next Right Pointers in Each Node
阅读量:5318 次
发布时间:2019-06-14

本文共 1957 字,大约阅读时间需要 6 分钟。

Populating Next Right Pointers in Each Node 题解

原创文章,拒绝转载

题目来源:


Description

Given a binary tree

struct TreeLinkNode {    TreeLinkNode *left;    TreeLinkNode *right;    TreeLinkNode *next;}

Populate each next pointer to point to its next right node. If there is no next right node, the next pointer should be set to NULL.

Initially, all next pointers are set to NULL.

Note:

  • You may only use constant extra space.
  • You may assume that it is a perfect binary tree (ie, all leaves are at the same level, and every parent has two children).

Example

Given the following perfect binary tree,

1       /  \      2    3     / \  / \    4  5  6  7

After calling your function, the tree should look like:

1 -> NULL       /  \      2 -> 3 -> NULL     / \  / \    4->5->6->7 -> NULL

Solution

class Solution {private:    void connectNode(vector
& v) { int size = v.size(); for (int i = 0; i <= size - 2; i++) { v[i] -> next = v[i + 1]; } }public: void connect(TreeLinkNode *root) { if (root == NULL) return; int levelNodeNum = 1; int curLevelNodeNum = 0; queue
q; vector
v; q.push(root); while (!q.empty()) { TreeLinkNode* node = q.front(); q.pop(); v.push_back(node); if (node -> left != NULL) q.push(node -> left); if (node -> right != NULL) q.push(node -> right); curLevelNodeNum++; if (curLevelNodeNum == levelNodeNum) { levelNodeNum *= 2; curLevelNodeNum = 0; connectNode(v); v.clear(); } } }};

解题描述

这道题是关于二叉树层次遍历问题的变种。题目给出的二叉树是完全二叉树,所以可以提前算出每一层的节点数目,因此来说还是相对比较容易的。所以基本的解决办法是,使用一个队列来存放节点。最开始将根节点加入队列。每次从队首取出一个节点,将其子节点加入队尾。然后使用一个计数变量来计算当前层次上已经加入队列的节点数目。一旦达到该层次的节点数目总和就对该层的节点进行next连接。

转载于:https://www.cnblogs.com/yanhewu/p/8041064.html

你可能感兴趣的文章
2018.11.06 bzoj1040: [ZJOI2008]骑士(树形dp)
查看>>
2019.02.15 bzoj5210: 最大连通子块和(链分治+ddp)
查看>>
redis cluster 集群资料
查看>>
微软职位内部推荐-Sr. SE - Office incubation
查看>>
微软职位内部推荐-SOFTWARE ENGINEER II
查看>>
centos系统python2.7更新到3.5
查看>>
【Quartz】常用方法的使用方式(三)
查看>>
MVVM模式下关闭窗口的实现
查看>>
C#区域截图——调用API截图
查看>>
c#与java中byte字节的区别及转换方法
查看>>
A WebBrowser Toy
查看>>
用MyXls生成Excel报表(C#)
查看>>
了解WP的传感器
查看>>
阅读笔记 火球——UML大战需求分析 2
查看>>
acedEvaluateLisp函数的反汇编
查看>>
Linux无线工具详解(Wireless tools for Linux)
查看>>
RSS阅读器
查看>>
微信电脑版不断崩溃
查看>>
js链式调用
查看>>
数字统计
查看>>