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

首頁 > 學院 > 開發設計 > 正文

116. Populating Next Right Pointers in Each Node

2019-11-14 09:41:50
字體:
來源:轉載
供稿:網友

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

解法一,使用隊列,時間復雜度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); }};

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


發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
主站蜘蛛池模板: 镇赉县| 乌拉特前旗| 江华| 平南县| 隆子县| 蓬溪县| 旌德县| 高雄市| 洞口县| 平远县| 迭部县| 米林县| 洮南市| 阿拉善右旗| 哈巴河县| 禄劝| 怀集县| 绥棱县| 尚义县| 法库县| 嵊泗县| 潞城市| 凤冈县| 彰武县| 邵阳县| 昌都县| 平乡县| 宁城县| 灵台县| 荣成市| 舟曲县| 诸城市| 绥滨县| 灵丘县| 望奎县| 洛南县| 上虞市| 营山县| 朝阳区| 瓦房店市| 龙南县|