102. 二叉树的层序遍历
问题描述
给你二叉树的根节点 root ,返回其节点值的 层序遍历 。 (即逐层地,从左到右访问所有节点)。
分析
对于nullptr:
- 先判不空再入队
- 入队列后在for中判空,为空则continue
第一种更好,因为如果为空,即使continue也会影响全局,比如该题中res.push_back(layer_res);当某层结点为空,则layer_res为空,res会多了一个nullptr。当然可以处理,不过显然第一种更简洁。
bfs解法
class Solution {
public:
vector<vector<int>> levelOrder(TreeNode* root) {
vector<vector<int> > res;
queue<TreeNode*> q;
if (root != nullptr) {
q.push(root);
}
while(!q.empty()) {
int layer_size = q.size();
vector<int> layer_res;
for (int i = 0; i < layer_size; i++) {
TreeNode* t = q.front();
q.pop();
layer_res.push_back(t->val);
if (t->left != nullptr) {
q.push(t->left);
}
if (t->right != nullptr) {
q.push(t->right);
}
}
res.push_back(layer_res);
}
return res;
}
};
· 分享一个免费、快速、无限量使用的满血 DeepSeek R1 模型,支持深度思考和联网搜索!
· 使用C#创建一个MCP客户端
· ollama系列1:轻松3步本地部署deepseek,普通电脑可用
· 基于 Docker 搭建 FRP 内网穿透开源项目(很简单哒)
· 按钮权限的设计及实现