C语言数据结构(14)--二叉树的链式存储结构

简介: 本文目录1. 模型构建2. 节点结构体定义3. 二叉树的构造与遍历

1. 模型构建

二叉树如下图,是由节点、节点与节点之前的连接组成的,而且连接是有顺序的,一般我们认为左边的次序要优先于右边。

image.png

对于每个节点来说,都有一个数据区域存放该节点的信息,另外还需要描述其左右子节点。每个节点的这三个信息确认之后,其实整个树的信息就确认了。


2. 节点结构体定义

typedef struct {

int data;//数据区域

struct BinaryTreeNode* left;//左子节点

struct BinaryTreeNode* right;//右子节点

}BinaryTreeNode;

1

2

3

4

5

非常完美吭,不再解释了。


3. 二叉树的构造与遍历

非常简单啊,从根节点开始逐次构造即可,看代码

#include<stdio.h>
/*
* 使用链表构造与遍历二叉树
* 作者:熊猫大大
* 时间:2019-12-01
*/
#include <stdio.h>
typedef struct {
  int data;//数据区域
  struct BinaryTreeNode* left;//左子节点
  struct BinaryTreeNode* right;//右子节点
}BinaryTreeNode;
//为树的当前节点添加左子节点
int addLeftChild(BinaryTreeNode* curNode, int leftData)
{
  //分配新节点
  BinaryTreeNode* leftNode = (BinaryTreeNode*)malloc(sizeof(BinaryTreeNode));
  //为新节点挂载数据
  leftNode->data = leftData;
  //新节点暂时无子节点
  leftNode->left = NULL;
  leftNode->right = NULL;
  //将新节点挂到当前节点下
  curNode->left = leftNode;
  return 1;
}
//为树的当前节点添加右子节点
int addRightChild(BinaryTreeNode* curNode,int rightData)
{
  //分配新节点
  BinaryTreeNode* rightNode = (BinaryTreeNode*)malloc(sizeof(BinaryTreeNode));
  //为新节点挂载数据
  rightNode->data = rightData;
  //新节点暂时无子节点
  rightNode->left = NULL;
  rightNode->right = NULL;
  //将新节点挂到当前节点下
  curNode->right = rightNode;
  return 1;
}
//遍历当前节点与子节点
void printTree(BinaryTreeNode *node)
{
  if (node == NULL) {
    return;
  }
  printf("父节点:%d", node->data);
  printf("----");
  BinaryTreeNode* temp = NULL;
  if (node->left != NULL) 
  {
    temp = node->left;
    printf("左:%d", temp->data);
  }
  if (node->right != NULL)
  {
    temp = node->right;
    printf("右:%d", temp->data);
  }
  printf("\n");
  printTree(node->left);
  printTree(node->right);
}
//----------------------------------------------------------------------------------------------------测试入口区域
int main()
{
  //设定根节点
  BinaryTreeNode root;
  //根节点
  root.data = 1;
  root.left = NULL;
  root.right = NULL;
  addLeftChild(&root, 2);
  addRightChild(&root, 3);
  //为2号节点增加子节点
  addLeftChild(root.left, 4);
  addRightChild(root.left, 5);
  printTree(&root);
  return 1;
}

image.png


相关文章
|
5天前
|
C语言
【C语言基础篇】结构控制(中)循环结构
【C语言基础篇】结构控制(中)循环结构
|
5天前
|
存储 算法
【数据结构和算法】--- 二叉树(4)--二叉树链式结构的实现(2)
【数据结构和算法】--- 二叉树(4)--二叉树链式结构的实现(2)
9 0
|
4天前
|
存储 Python
Python中使用列表和字典来存储和处理复杂的数据结构
Python中使用列表和字典来存储和处理复杂的数据结构
|
4天前
|
存储 自然语言处理 NoSQL
深入解析Elasticsearch的内部数据结构和机制:行存储、列存储与倒排索引之倒排索引(三)
深入解析Elasticsearch的内部数据结构和机制:行存储、列存储与倒排索引之倒排索引(三)
|
4天前
|
存储 自然语言处理 NoSQL
深入解析Elasticsearch的内部数据结构和机制:行存储、列存储与倒排索引之列存(二)
深入解析Elasticsearch的内部数据结构和机制:行存储、列存储与倒排索引之列存(二)
|
4天前
|
存储 JSON NoSQL
深入解析Elasticsearch的内部数据结构和机制:行存储、列存储与倒排索引之行存(一)
深入解析Elasticsearch的内部数据结构和机制:行存储、列存储与倒排索引之行存(一)
|
4天前
|
存储 缓存 NoSQL
Redis为什么速度快:数据结构、存储及IO网络原理总结
Redis为什么速度快:数据结构、存储及IO网络原理总结
|
4天前
|
存储 算法 Java
Java数据结构与算法:用于高效地存储和检索字符串数据集
Java数据结构与算法:用于高效地存储和检索字符串数据集
|
5天前
|
存储 C语言
【海贼王编程冒险 - C语言海上篇】C语言中的数据类型有哪些?又是如何存储?
【海贼王编程冒险 - C语言海上篇】C语言中的数据类型有哪些?又是如何存储?
11 0
|
5天前
|
算法 C语言
【数据结构与算法 经典例题】链表的回文结构(图文详解)
【数据结构与算法 经典例题】链表的回文结构(图文详解)