当前位置: 首页 > wzjs >正文

云南凡科建站广州日新增51万人

云南凡科建站,广州日新增51万人,苹果官网序列号查询,一键清理垃圾自动清理C#二叉树 二叉树是一种常见的数据结构,它是由节点组成的一种树形结构,其中每个节点最多有两个子节点。二叉树的一个节点通常包含三部分:存储数据的变量、指向左子节点的指针和指向右子节点的指针。二叉树可以用于多种算法和操作,…

C#二叉树

二叉树是一种常见的数据结构,它是由节点组成的一种树形结构,其中每个节点最多有两个子节点。二叉树的一个节点通常包含三部分:存储数据的变量、指向左子节点的指针和指向右子节点的指针。二叉树可以用于多种算法和操作,如搜索、排序和遍历。

在这里插入图片描述

二叉树遍历

遍历方式顺序C#递归实现核心代码
前序遍历根 → 左 → 右Console.Write(root.val); → 递归左 → 递归右
中序遍历左 → 根 → 右递归左 → Console.Write(root.val); → 递归右
后序遍历左 → 右 → 根递归左 → 递归右 → Console.Write(root.val);

二叉树的应用场景

  1. 快速查找与排序
    • 二叉搜索树用于实现字典、数据库索引(如B树、B+树的基础)。
  2. 表达式树
    • 编译器解析数学表达式时构建二叉树,叶节点为操作数,非叶节点为运算符。
  3. 哈夫曼编码
    • 通过构建最优二叉树实现数据压缩。
  4. 决策树与机器学习
    • 二叉树结构用于分类和回归模型的决策过程。

二叉树的优缺点

优点缺点
逻辑清晰,易于实现递归操作普通二叉树可能退化为链表(时间复杂度升至O(n))
二叉搜索树支持高效查找/插入平衡二叉树实现复杂(如AVL树的旋转操作)
天然适合分治算法(如快速排序)存储指针占用额外内存空间
实例1
using System;
using System.Collections.Generic;public class TreeNode
{public int val;public TreeNode left;public TreeNode right;public TreeNode(int x) { val = x; }
}class BinaryTreeDemo
{static void Main(){// 构建二叉树TreeNode root = new TreeNode(1){left = new TreeNode(2){left = new TreeNode(4),right = new TreeNode(5)},right = new TreeNode(3)};Console.WriteLine("前序遍历:");PreOrder(root); // 输出: 1 2 4 5 3Console.WriteLine("\n层序遍历:");LevelOrder(root); // 输出: 1 2 3 4 5}// 前序遍历static void PreOrder(TreeNode root){if (root == null) return;Console.Write(root.val + " ");PreOrder(root.left);PreOrder(root.right);}// 层序遍历static void LevelOrder(TreeNode root){if (root == null) return;Queue<TreeNode> queue = new Queue<TreeNode>();queue.Enqueue(root);while (queue.Count > 0){TreeNode node = queue.Dequeue();Console.Write(node.val + " ");if (node.left != null) queue.Enqueue(node.left);if (node.right != null) queue.Enqueue(node.right);}}
}
实例2
public class TreeNode<T>
{public T Value { get; set; }public TreeNode<T> Left { get; set; }public TreeNode<T> Right { get; set; }public TreeNode(T value){Value = value;Left = null;Right = null;}
}public class BinaryTree<T>
{public TreeNode<T> Root { get; private set; }public BinaryTree(){Root = null;}// 插入新值到二叉树中public void Add(T value){if (Root == null){Root = new TreeNode<T>(value);}else{AddTo(Root, value);}}private void AddTo(TreeNode<T> node, T value){if (Comparer<T>.Default.Compare(value, node.Value) < 0){if (node.Left == null){node.Left = new TreeNode<T>(value);}else{AddTo(node.Left, value);}}else{if (node.Right == null){node.Right = new TreeNode<T>(value);}else{AddTo(node.Right, value);}}}// 前序遍历(根-左-右)public void PreOrderTraversal(TreeNode<T> node){if (node != null){Console.WriteLine(node.Value); // 访问节点PreOrderTraversal(node.Left);   // 遍历左子树PreOrderTraversal(node.Right);  // 遍历右子树}}// 中序遍历(左-根-右)public void InOrderTraversal(TreeNode<T> node){if (node != null){InOrderTraversal(node.Left);   // 遍历左子树Console.WriteLine(node.Value); // 访问节点InOrderTraversal(node.Right);  // 遍历右子树}}// 后序遍历(左-右-根)public void PostOrderTraversal(TreeNode<T> node){if (node != null){PostOrderTraversal(node.Left);   // 遍历左子树PostOrderTraversal(node.Right);  // 遍历右子树Console.WriteLine(node.Value);   // 访问节点}}
}
实例3
class BSTDemo
{static void Main(){TreeNode root = null;// 插入节点root = InsertBST(root, 5);InsertBST(root, 3);InsertBST(root, 7);InsertBST(root, 2);Console.WriteLine("中序遍历BST:");InOrder(root); // 输出: 2 3 5 7// 删除节点3root = DeleteNode(root, 3);Console.WriteLine("\n删除后:");InOrder(root); // 输出: 2 5 7}// BST插入static TreeNode InsertBST(TreeNode root, int val){if (root == null) return new TreeNode(val);if (val < root.val)root.left = InsertBST(root.left, val);elseroot.right = InsertBST(root.right, val);return root;}// BST删除(使用之前定义的DeleteNode方法)// 中序遍历static void InOrder(TreeNode root){if (root == null) return;InOrder(root.left);Console.Write(root.val + " ");InOrder(root.right);}
}
实例4
class SymmetricTreeDemo
{static void Main(){// 对称二叉树TreeNode root1 = new TreeNode(1){left = new TreeNode(2) { left = new TreeNode(3), right = new TreeNode(4) },right = new TreeNode(2) { left = new TreeNode(4), right = new TreeNode(3) }};// 非对称二叉树TreeNode root2 = new TreeNode(1){left = new TreeNode(2) { right = new TreeNode(3) },right = new TreeNode(2) { right = new TreeNode(3) }};Console.WriteLine("root1是否对称: " + IsSymmetric(root1)); // trueConsole.WriteLine("root2是否对称: " + IsSymmetric(root2)); // false}static bool IsSymmetric(TreeNode root){if (root == null) return true;return CheckSymmetric(root.left, root.right);}static bool CheckSymmetric(TreeNode left, TreeNode right){if (left == null && right == null) return true;if (left == null || right == null) return false;return left.val == right.val && CheckSymmetric(left.left, right.right)&& CheckSymmetric(left.right, right.left);}
}
实例5
class DepthDemo
{static void Main(){TreeNode root = new TreeNode(1){left = new TreeNode(2) { left = new TreeNode(4) },right = new TreeNode(3)};Console.WriteLine("最大深度: " + MaxDepth(root)); // 输出: 3}static int MaxDepth(TreeNode root){if (root == null) return 0;return Math.Max(MaxDepth(root.left), MaxDepth(root.right)) + 1;}
}
实例6
class PathSumDemo
{static void Main(){TreeNode root = new TreeNode(5){left = new TreeNode(4) { left = new TreeNode(11) { left = new TreeNode(7), right = new TreeNode(2) } },right = new TreeNode(8) { left = new TreeNode(13), right = new TreeNode(4) { right = new TreeNode(1) } }};Console.WriteLine("是否存在和为22的路径: " + HasPathSum(root, 22)); // true}static bool HasPathSum(TreeNode root, int targetSum){if (root == null) return false;if (root.left == null && root.right == null)return root.val == targetSum;return HasPathSum(root.left, targetSum - root.val) || HasPathSum(root.right, targetSum - root.val);}
}

关键点总结

  1. 递归思想:二叉树问题多通过递归解决,注意终止条件(root == null
  2. BST特性:插入/删除时利用左小右大规则
  3. 遍历选择
    • 前序:根节点最先访问
    • 中序:BST会得到有序序列
    • 层序:需要队列辅助
  4. 空间复杂度
    • 递归:O(h)(h为树高)
    • 层序:O(n)
http://www.dtcms.com/wzjs/116651.html

相关文章:

  • 汽车商城网站建设沈阳seo排名优化软件
  • 河南郑州旅游网站设计潍坊网站seo
  • 开网站流程品牌互动营销案例
  • 贵阳做网站方舟网络百度联系电话多少
  • 移动端网站和app区别武汉seo结算
  • 河南省住房和建设厅网站首页合肥网站优化排名推广
  • 怎么给喜欢的人做网站大数据营销名词解释
  • 武汉网站开发制作个人网站怎么做
  • django 网站开发论文外包公司什么意思
  • 如何制作网站设计什么软件引流客源最快
  • 免费网站设计素材什么是网络营销策略
  • 百度不抓取网站appstore关键词优化
  • 智慧团建网站官网入口登录seo积分优化
  • 网站建设公司设计网页的工具seo公司哪家好用
  • 大连商城网站建设百度关键词优化多久上首页
  • python编程软件pc手机系统优化工具
  • 电影网站开发教程app推广公司怎么对接业务
  • 品牌建设汇报淘宝seo搜索优化工具
  • 语言互动网站建设怎么建立公司网站
  • 做能支付的网站贵吗百度电话号码
  • 制作网站的公司哪个部门监管网站seo优化的目的
  • 网站后台怎么做外部链接清博大数据舆情监测平台
  • 新东方在线网上课程贵阳百度seo点击软件
  • php网站开发简历最新seo新手教程
  • 郑州做网站那家做的好武汉seo搜索引擎优化
  • 网站放在服务器上武汉百度开户代理
  • 现在pc端网站开发用的什么技术加强服务保障满足群众急需i
  • 自己怎么做专属自己的网站优化营商环境条例心得体会
  • wordpress自定义图片免费seo优化工具
  • 定制网站开发方案今日竞彩足球最新比赛结果查询