news 2026/6/10 22:42:48

在C语言中,可以通过**先序遍历的方式输入数据**来创建一个二叉链表表示的二叉树

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
在C语言中,可以通过**先序遍历的方式输入数据**来创建一个二叉链表表示的二叉树

在C语言中,可以通过先序遍历的方式输入数据来创建一个二叉链表表示的二叉树。通常约定以某个特殊值(如-1)表示空结点,用于标识子树的结束。

🌲 创建思路(递归方式)

根据先序遍历的顺序:根 → 左 → 右,我们依次读入数据:

  • 若输入为-1,表示该子树为空,返回NULL
  • 否则,为当前节点分配内存,赋值,并递归创建左子树和右子树。

✅ C语言实现代码

#include<stdio.h>#include<stdlib.h>// 二叉树结点定义typedefstructBiTNode{intdata;structBiTNode*lchild,*rchild;}BiTNode,*BiTree;// 按先序输入数据创建二叉树(-1 表示空结点)voidCreateBiTree(BiTree*root){intval;scanf("%d",&val);if(val==-1){*root=NULL;// 空结点}else{*root=(BiTNode*)malloc(sizeof(BiTNode));if(!*root){printf("内存分配失败!\n");exit(1);}(*root)->data=val;// 设置根节点数据CreateBiTree(&(*root)->lchild);// 递归创建左子树CreateBiTree(&(*root)->rchild);// 递归创建右子树}}// 示例:先序遍历输出验证voidPreOrder(BiTree root){if(root!=NULL){printf("%d ",root->data);PreOrder(root->lchild);PreOrder(root->rchild);}}// 主函数测试intmain(){BiTree T;printf("请输入先序序列构建二叉树(-1 表示空结点):\n");CreateBiTree(&T);printf("先序遍历结果为:");PreOrder(T);printf("\n");return0;}

🧪 输入示例

假设我们要构建如下二叉树:

1 / \ 2 3 / \ 4 5

对应的先序输入序列为(补全空指针用 -1):

1 2 4 -1 -1 5 -1 -1 3 -1 -1

每个-1对应一个空左右孩子,完整反映树结构。


🔍 注意事项

  • 必须严格按照先序结构输入,包括所有叶子结点的左右空指针。
  • 使用指针的地址(BiTree *root)是为了修改实参指针本身。
  • 动态内存分配需检查是否成功,避免野指针或崩溃。

// 一、二叉链表的结点类型定义typedefstructBiTNode{intdata;structBiTNode*lchild,*rchild;}BiTNode,*BiTree;// 二、二叉树的遍历方式// 先序遍历:根 → 左 → 右voidPreOrder(BiTree root){if(root!=NULL){printf("%d ",root->data);// 访问根节点PreOrder(root->lchild);// 遍历左子树PreOrder(root->rchild);// 遍历右子树}}// 中序遍历:左 → 根 → 右voidInOrder(BiTree root){if(root!=NULL){InOrder(root->lchild);// 遍历左子树printf("%d ",root->data);// 访问根节点InOrder(root->rchild);// 遍历右子树}}// 后序遍历:左 → 右 → 根voidPostOrder(BiTree root){if(root!=NULL){PostOrder(root->lchild);// 遍历左子树PostOrder(root->rchild);// 遍历右子树printf("%d ",root->data);// 访问根节点}}

通过先序遍历中序遍历序列可以唯一重建一棵二叉树(前提是不含重复值)。

🔍 重建原理

  • 先序遍历:顺序为根 → 左子树 → 右子树,所以第一个元素就是当前子树的根节点
  • 中序遍历:顺序为左子树 → 根 → 右子树,因此可以在中序序列中找到根的位置,从而划分出左右子树的范围。

利用这两个特性,可以递归构造二叉树


✅ 算法步骤

  1. 从先序序列中取出当前根节点(初始为第一个元素)。
  2. 在中序序列中查找该根的位置,将其分为:
    • 左半部分:左子树的中序序列
    • 右半部分:右子树的中序序列
  3. 根据左子树结点数量,确定先序序列中对应的部分。
  4. 递归构建左子树和右子树。

✅ C语言实现代码

#include<stdio.h>#include<stdlib.h>// 二叉树结点定义typedefstructBiTNode{intdata;structBiTNode*lchild,*rchild;}BiTNode,*BiTree;// 查找元素在数组中的位置intsearch(intarr[],intstart,intend,intvalue){for(inti=start;i<=end;i++){if(arr[i]==value)returni;}return-1;}// 使用先序和中序序列重建二叉树BiTreebuildTree(intpreorder[],intinorder[],intpreStart,intinStart,intinEnd){if(inStart>inEnd)returnNULL;// 创建根节点(当前先序起点)BiTree root=(BiTNode*)malloc(sizeof(BiTNode));if(!root){printf("内存分配失败!\n");exit(1);}root->data=preorder[preStart];root->lchild=root->rchild=NULL;// 如果没有子树(叶子),直接返回if(inStart==inEnd)returnroot;// 在中序中找根的位置,划分左右子树intinRootIndex=search(inorder,inStart,inEnd,root->data);// 计算左子树结点数intleftSubtreeSize=inRootIndex-inStart;// 递归构建左子树和右子树root->lchild=buildTree(preorder,inorder,preStart+1,inStart,inRootIndex-1);root->rchild=buildTree(preorder,inorder,preStart+leftSubtreeSize+1,inRootIndex+1,inEnd);returnroot;}// 中序遍历验证结果voidInOrder(BiTree root){if(root!=NULL){InOrder(root->lchild);printf("%d ",root->data);InOrder(root->rchild);}}// 先序遍历验证结果voidPreOrder(BiTree root){if(root!=NULL){printf("%d ",root->data);PreOrder(root->lchild);PreOrder(root->rchild);}}// 主函数测试intmain(){intn;printf("请输入节点个数:");scanf("%d",&n);intpreorder[n],inorder[n];printf("请输入先序遍历序列:");for(inti=0;i<n;i++)scanf("%d",&preorder[i]);printf("请输入中序遍历序列:");for(inti=0;i<n;i++)scanf("%d",&inorder[i]);BiTree T=buildTree(preorder,inorder,0,0,n-1);printf("重建完成!\n");printf("先序遍历验证:");PreOrder(T);printf("\n");printf("中序遍历验证:");InOrder(T);printf("\n");return0;}

🧪 示例输入输出

假设:

  • 先序:[1, 2, 4, 5, 3]
  • 中序:[4, 2, 5, 1, 3]

程序将重建如下二叉树:

1 / \ 2 3 / \ 4 5

输出验证:

  • 先序:1 2 4 5 3
  • 中序:4 2 5 1 3

⚠️ 注意事项

  • 所有节点值应不重复,否则search函数可能定位错误。
  • 数组长度需一致,且输入合法。
  • 可优化使用哈希表(如静态映射数组)加速查找(适用于数据范围小的情况)。

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

LangGraph多智能体协作实战:从零开始构建大模型应用

本文详细介绍了使用LangGraph框架实现多智能体协作的实践案例&#xff0c;通过状态图管理四个智能体节点和条件边&#xff0c;利用MemorySaver实现上下文记忆&#xff0c;构建支持多轮对话的高考信息查询助手&#xff0c;并与AgentScope框架进行了对比分析&#xff0c;展示了La…

作者头像 李华
网站建设 2026/6/10 12:32:37

【小白必看】大模型基础算法深度解析:收藏这篇就够了

本文详细解析了大模型的基础算法流程&#xff0c;从文本分词、词嵌入到Transformer处理&#xff0c;并深入介绍了BPE分词、DeepNorm、FlashAttention、GQA和RoPE等关键技术&#xff0c;帮助读者理解大模型的工作原理和优化方法&#xff0c;适合小白和程序员系统学习大模型基础知…

作者头像 李华
网站建设 2026/6/10 12:58:30

MySQL 分区:提高查询效率还是反噬?

在当今大数据时代&#xff0c;数据库性能优化成为了技术领域的热点话题。MySQL 作为最流行的开源关系型数据库管理系统之一&#xff0c;其性能优化一直是开发者们关注的焦点。其中&#xff0c;分区&#xff08;Partitioning&#xff09;技术常被提及为提高查询效率的一种手段。…

作者头像 李华
网站建设 2026/6/10 13:00:00

为什么conda安装PyTorch时候会安装CUDA Toolkit,而pip则不需要?

在深度学习领域&#xff0c;PyTorch 是一个非常流行的框架&#xff0c;它提供了强大的工具和库&#xff0c;使得开发者可以轻松地构建和训练复杂的神经网络模型。然而&#xff0c;在安装 PyTorch 的过程中&#xff0c;很多用户发现通过 conda 安装时会自动安装 CUDA Toolkit&am…

作者头像 李华
网站建设 2026/6/10 13:01:08

从告警延迟到实时通知:重构PHP监控系统的7个技术决策点

第一章&#xff1a;从被动响应到主动预警&#xff1a;PHP监控系统的演进之路在早期的PHP应用运维中&#xff0c;系统监控多依赖于错误日志轮询和手动排查&#xff0c;属于典型的“被动响应”模式。开发团队往往在用户反馈故障后才介入处理&#xff0c;导致问题发现滞后、修复周…

作者头像 李华
网站建设 2026/6/10 13:01:12

如何在24小时内掌握R语言空间自相关分析?这份速成清单必须收藏

第一章&#xff1a;R语言空间自相关分析的核心概念空间自相关分析是地理统计学中的关键方法&#xff0c;用于衡量空间位置上的观测值是否存在聚集性或分散模式。在R语言中&#xff0c;该分析依赖于空间数据结构与统计指标的结合&#xff0c;帮助研究者识别数据的空间依赖性。空…

作者头像 李华