news 2026/5/7 2:59:07

12.12 - 二叉树的层序遍历 C语言函数指针和指针函数的区别

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
12.12 - 二叉树的层序遍历 C语言函数指针和指针函数的区别

目录

1.二叉树的层序遍历

a.核心思想

b.思路

c.步骤

2.C语言函数指针和指针函数的区别

a.函数指针

b.指针函数

c.核心区别


1.二叉树的层序遍历

102. 二叉树的层序遍历 - 力扣(LeetCode)https://leetcode.cn/problems/binary-tree-level-order-traversal/

/** * Definition for a binary tree node. * struct TreeNode { * int val; * TreeNode *left; * TreeNode *right; * TreeNode() : val(0), left(nullptr), right(nullptr) {} * TreeNode(int x) : val(x), left(nullptr), right(nullptr) {} * TreeNode(int x, TreeNode *left, TreeNode *right) : val(x), left(left), right(right) {} * }; */ class Solution { public: vector<vector<int>> levelOrder(TreeNode* root) { vector<vector<int>> retvv; // 1. 处理特殊情况 if(root == nullptr) return retvv; // 2. 创建队列用于BFS,初始加入根节点 queue<TreeNode*> q; q.push(root); // 3. BFS主循环:队列非空时持续遍历 while(!q.empty()) { // 记录当前层节点数(关键:队列此时的大小就是当前层的节点总数) int levelsize = q.size(); vector<int> curv; for(int i = 0; i < levelsize; i++) { // 取出队首节点并移除 TreeNode* node = q.front(); q.pop(); // 保存该层的节点 curv.push_back(node->val); // 非空节点入队 if(node->left) q.push(node->left); if(node->right) q.push(node->right); } retvv.push_back(curv); } return retvv; } };

a.核心思想

利用广度优先搜索(BFS)的策略,按层次依次访问二叉树的节点,将每一层的节点值收集起来,形成层序遍历的结果。

b.思路

通过队列来辅助实现广度优先搜索。首先将根节点入队,然后在队列不为空的情况下,循环取出队列中的节点,将其值加入当前层的结果列表,并将其存在的左右子节点依次入队,当处理完当前层的所有节点后,将当前层的结果列表加入最终结果中。

c.步骤

① 初始化一个队列,将二叉树的根节点入队。

② 初始化一个结果列表用于存储层序遍历的结果。

③ 当队列不为空时,重复以下步骤:

  • 获取当前队列的大小,即当前层的节点数。

  • 初始化一个临时列表用于存储当前层的节点值。

  • 循环当前层的节点数次,每次从队列中取出一个节点,将其值加入临时列表,并将其左右子节点(如果存在)入队。

  • 将临时列表加入结果列表。

④ 返回结果列表。

2.C语言函数指针和指针函数的区别

a.函数指针

函数指针:指向函数的指针,本质是指针
定义形式:返回类型 (*指针名)(参数列表),如int (*p)(int)表示p是指向返回int且接受int参数的函数的指针。

b.指针函数

指针函数:返回指针的函数,本质是函数
定义形式:返回类型 *函数名(参数列表),如int *func(int)表示func是返回int*类型指针的函数。

c.核心区别

函数指针:指向函数,用于间接调用函数(如回调、函数数组)。

指针函数:返回指针,用于动态生成地址(如返回数组首地址、动态内存地址)。

希望这些内容对大家有所帮助!

感谢大家的三连支持!

版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/4/30 23:33:50

嵌入式-硬件基础:了解三极管

目录 一、三极管的本质&#xff1a;半导体电流控制器 1. 核心定义 2. 结构与材料 3. 两种类型&#xff1a;NPN 型 vs PNP 型 二、工作原理&#xff1a;“以小控大” 的核心逻辑 1. 导通的前提&#xff1a;正确偏置 2. 载流子的运动过程&#xff08;三步曲&#xff09; …

作者头像 李华
网站建设 2026/5/5 17:29:01

【Java方法】--让你的代码变成一个独立的“任务”——方法

个人主页 目录前言1. 什么是方法&#xff1f;为什么我们需要它&#xff1f;2. 如何定义一个Java方法&#xff1f;**代码示例&#xff1a;**3. 如何调用方法&#xff1f;**代码示例&#xff1a;**4. 拓展&#xff1a;命令行传递参数**如何使用&#xff1f;**结尾前言 想象一下&a…

作者头像 李华
网站建设 2026/5/1 0:25:41

5分钟用vue.config.js搭建开发环境原型

快速体验 打开 InsCode(快马)平台 https://www.inscode.net输入框内输入如下内容&#xff1a; 请快速生成一个可用于原型开发的vue.config.js配置&#xff0c;要求&#xff1a;1. 配置热重载 2. 设置/api代理到本地3000端口 3. 允许跨域 4. 配置ESLint自动修复 5. 添加vue-rou…

作者头像 李华
网站建设 2026/5/3 10:29:44

小白必看:什么是WiFi密码字典及其基本用法

快速体验 打开 InsCode(快马)平台 https://www.inscode.net输入框内输入如下内容&#xff1a; 创建一个交互式WiFi密码字典学习应用&#xff0c;通过简单示例演示密码字典的工作原理。要求包含基础知识讲解、简单字典生成演示和实际应用场景说明。使用HTMLJavaScript实现可视化…

作者头像 李华
网站建设 2026/5/3 14:27:34

传统调试 vs AI辅助:解决Internal Server Error的效率对比

快速体验 打开 InsCode(快马)平台 https://www.inscode.net输入框内输入如下内容&#xff1a; 构建一个对比工具&#xff0c;左侧展示传统调试步骤&#xff08;查看日志、手动排查等&#xff09;&#xff0c;右侧展示AI辅助调试流程&#xff08;自动分析、建议修复&#xff09…

作者头像 李华
网站建设 2026/4/30 23:39:55

系统迁移时如何处理Temp文件夹?专家建议

快速体验 打开 InsCode(快马)平台 https://www.inscode.net输入框内输入如下内容&#xff1a; 开发一个系统迁移辅助工具&#xff0c;专门处理Temp目录&#xff1a;1) 分析临时文件使用情况 2) 智能识别需要保留的文件 3) 生成迁移报告 4) 支持自定义过滤规则 5) 与主流迁移工…

作者头像 李华