温馨提示×

温馨提示×

您好,登录后才能下订单哦!

密码登录×
登录注册×
其他方式登录
点击 登录注册 即表示同意《亿速云用户服务条款》

199. 二叉树的右视图

发布时间:2020-08-05 17:58:41 来源:网络 阅读:145 作者:wx5d3c7e0ad6c30 栏目:编程语言

给定一棵二叉树,想象自己站在它的右侧,按照从顶部到底部的顺序,返回从右侧所能看到的节点值。

示例:

输入: [1,2,3,null,5,null,4]
输出: [1, 3, 4]
解释:

1 <---
/ \
2 3 <---
\ \
5 4 <---

解题思路:层次遍历树中的每一个结点,同时result只记录每一层中的一个结点,如果不是最右边的结点更新即可.,
代码实现


/** * Definition for a binary tree node. * struct TreeNode { * int val; * TreeNode *left; * TreeNode *right; * TreeNode(int x) : val(x), left(NULL), right(NULL) {} * }; */ class Solution { public: vector<int> rightSideView(TreeNode* root) { vector<int> result; if(root == NULL) return result; queue<pair<TreeNode*,int> > Queue; Queue.push(make_pair(root,0)); while(!Queue.empty()) { TreeNode* node = Queue.front().first; int step = Queue.front().second; Queue.pop(); if(step == result.size()) result.push_back(node->val); else result[step] = node->val; if(node->left) { Queue.push(make_pair(node->left,step + 1)); } if(node->right) { Queue.push(make_pair(node->right, step + 1)); } } return result; } };
向AI问一下细节

免责声明:本站发布的内容(图片、视频和文字)以原创、转载和分享为主,文章观点不代表本网站立场,如果涉及侵权请联系站长邮箱:is@yisu.com进行举报,并提供相关证据,一经查实,将立刻删除涉嫌侵权内容。

AI