国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

首頁 > 學(xué)院 > 開發(fā)設(shè)計(jì) > 正文

116. Populating Next Right Pointers in Each Node

2019-11-14 09:36:55
字體:
供稿:網(wǎng)友

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). For 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

解法一,使用隊(duì)列,時(shí)間復(fù)雜度O(N):

/** * Definition for binary tree with next pointer. * struct TreeLinkNode { * int val; * TreeLinkNode *left, *right, *next; * TreeLinkNode(int x) : val(x), left(NULL), right(NULL), next(NULL) {} * }; */class Solution {public: void connect(TreeLinkNode *root) { if(root == NULL) return ; std::queue<TreeLinkNode*> que; que.push(root); while(!que.empty()){ const int size = que.size(); for(int i=0; i<size; ++i){ TreeLinkNode* tmp = que.front(); que.pop(); if(!que.empty() && i != size-1) tmp->next = que.front(); //default tmp1->next = NULL; if(tmp->left != NULL) que.push(tmp->left); if(tmp->right != NULL) que.push(tmp->right); } } }};

解法二,遞歸:

class Solution {public: void connect(TreeLinkNode *root) { if(root == NULL) return ; if(root->left != NULL){ root->left->next = root->right; //perfect binary tree if(root->next != NULL) root->right->next = root->next->left; } connect(root->left); connect(root->right); }};

這道題一開始我使用遞歸,我一直想借助后續(xù)遍歷的思路。事實(shí)證明,不要死搬硬套!要針對實(shí)際情況遞歸。


發(fā)表評論 共有條評論
用戶名: 密碼:
驗(yàn)證碼: 匿名發(fā)表
主站蜘蛛池模板: 突泉县| 太谷县| 海安县| 黔西| 启东市| 赣州市| 易门县| 大洼县| 铜山县| 长沙市| 吴旗县| 建昌县| 广丰县| 壶关县| 仁布县| 神木县| 常德市| 东丰县| 巨鹿县| 泾阳县| 遂昌县| 西宁市| 焦作市| 哈密市| 扎鲁特旗| 安阳市| 六枝特区| 满城县| 万州区| 长兴县| 五河县| 永济市| 克山县| 竹山县| 武隆县| 将乐县| 蒙城县| 康定县| 河北省| 吉林市| 河南省|