二叉树c语言实现完整代码
  二叉树是一种非常常见的数据结构,它由节点和边组成,每个节点最多有两个子节点,分别称为左子节点和右子节点。在计算机科学中,二叉树被广泛应用于搜索、排序、编译器等领域。本文将介绍如何使用C语言实现二叉树的完整代码。
 
  我们需要定义二叉树的节点结构体。每个节点包含三个成员变量:数据、左子节点和右子节点。代码如下:
 
  ```
  struct TreeNode {
      int val;
      struct TreeNode *left;
      struct TreeNode *right;
  };
  ```
 
  接下来,我们需要实现二叉树的基本操作,包括创建节点、插入节点、删除节点、查节点等。这些操作可以通过递归实现。代码如下:
 
  ```
  // 创建节点
  struct TreeNode* createNode(int val) {
      struct TreeNode* node = (struct TreeNode*)malloc(sizeof(struct TreeNode));
二叉树定义      node->val = val;
      node->left = NULL;
      node->right = NULL;
      return node;
  }
 
  // 插入节点
  struct TreeNode* insertNode(struct TreeNode* root, int val) {
      if (root == NULL) {
          return createNode(val);
      }
      if (val < root->val) {
          root->left = insertNode(root->left, val);
      } else {
          root->right = insertNode(root->right, val);
      }
      return root;
  }
 
  // 删除节点
  struct TreeNode* deleteNode(struct TreeNode* root, int val) {
      if (root == NULL) {
          return NULL;
      }
      if (val < root->val) {
          root->left = deleteNode(root->left, val);
      } else if (val > root->val) {
          root->right = deleteNode(root->right, val);
      } else {
          if (root->left == NULL) {
              struct TreeNode* temp = root->right;
              free(root);
              return temp;
          } else if (root->right == NULL) {
              struct TreeNode* temp = root->left;
              free(root);
              return temp;
          }
          struct TreeNode* temp = findMin(root->right);
          root->val = temp->val;
          root->right = deleteNode(root->right, temp->val);
      }
      return root;
  }
 
  // 查节点
  struct TreeNode* searchNode(struct TreeNode* root, int val) {
      if (root == NULL || root->val == val) {
          return root;
      }
      if (val < root->val) {
          return searchNode(root->left, val);
      } else {
          return searchNode(root->right, val);
      }
  }
 
  // 查最小节点
  struct TreeNode* findMin(struct TreeNode* root) {
      while (root->left != NULL) {
          root = root->left;
      }
      return root;
  }
  ```
 
  我们需要实现二叉树的遍历操作,包括前序遍历、中序遍历和后序遍历。这些操作也可以通过递归实现。代码如下:
 
  ```
  // 前序遍历
  void preorderTraversal(struct TreeNode* root) {
      if (root == NULL) {
          return;
      }
      printf("%d ", root->val);
      preorderTraversal(root->left);
      preorderTraversal(root->right);
  }
 
  // 中序遍历
  void inorderTraversal(struct TreeNode* root) {

版权声明:本站内容均来自互联网,仅供演示用,请勿用于商业和其他非法用途。如果侵犯了您的权益请与我们联系QQ:729038198,我们将在24小时内删除。