Leetcode#117 Populating Next Right Pointers in Each Node II
二叉树的层次遍历。
对于每一层,依次把各节点连起来即可。
代码:
1 void connect(TreeLinkNode *root) { 2 if (!root) return; 3 4 queue<TreeLinkNode *> parents; 5 6 parents.push(root); 7 while (!parents.empty()) { 8 queue<TreeLinkNode *> children; 9 10 while (!parents.empty()) { 11 TreeLinkNode *p = parents.front(); 12 parents.pop(); 13 p->next = parents.empty() ? NULL : parents.front(); 14 if (p->left) 15 children.push(p->left); 16 if (p->right) 17 children.push(p->right); 18 } 19 parents = children; 20 } 21 }
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步