剑指offer:从上往下打印二叉树

class Solution{
public:
vector<int> PrintFromTopToBottom(TreeNode* root){
	if(root == nullptr) return vector<int>();
	queue <TreeNode*> q;
	q.push(root);
	vector<int> result;
	TreeNode* node =nullptr;
	while(!q.empty()){
		node =  q.front();
		if(node->left) q.push(node->left);
		if(node->right) q.push(node->right);
		result.push_back(node->val);
		q.pop();
	}
	return result;
 
}
};

先判断二叉树为空否,借助队列q,把二叉树的根节点压入队列,定义队列的指针node,在定义个最后输出的数组。当队列不为空,node指针往前走,如果它有左子树,把值放入队列,右子树也同理,q.pop()出队列,因为先进先出,然后把node指针指的值全放入最后的result中,这时result里的值就是顺序的二叉树排序。

#剑指offer#
全部评论
楼主可以把解法分析写在代码前面吗?
点赞 回复 分享
发布于 2023-03-29 09:33 甘肃

相关推荐

08-23 20:17
四川大学 C++
xxxzsfa:技术栈可以参考我这个给写,把知识点写出来起码能让面试官知道你是知道这个点的,不会的知识点可以不写,简历上写了但又答不上来就很尴尬了,可以给技术栈中的知识点和项目中的难点亮点加粗,学历不错,肯定会有大厂面的,刚开始可以先投中小厂练手,拿个offer保底再去面大厂,秋招可以正式和实习一起找,找工作是个需要长期坚持的过程,加油查看图片
点赞 评论 收藏
分享
点赞 评论 收藏
分享
评论
点赞
收藏
分享

创作者周榜

更多
牛客网
牛客网在线编程
牛客网题解
牛客企业服务