🏆 作者简介,愚公搬代码 🏆《头衔》:华为云特约编辑,华为云云享专家,华为开发者专家,华为产品云测专家,CSDN博客专家,阿里云专家博主,腾讯云优秀博主,掘金优秀博主,51CTO博客专家等。 🏆《近期荣誉》:2022年CSDN博客之星TOP2,2022年华为云十佳博主等。
🏆《博客内容》:.NET、Java、Python、Go、Node、前端、IOS、Android、鸿蒙、Linux、物联网、网络安全、大数据、人工智能、U3D游戏、小程序等相关领域知识。
🏆🎉欢迎 👍点赞✍评论⭐收藏
排序算法是一种将一组数据按照特定的规则进行排列的方法。排序算法通常用于对数据的处理,使得数据能够更容易地被查找、比较和分析。
下面是常见的11种排序算法:
二叉树排序是一种基于二叉搜索树的排序算法。其基本思想是将待排序的数据存储在二叉搜索树中,然后进行中序遍历输出这些数据,即可得到一个有序序列。
具体步骤如下:
因为二叉搜索树的性质,其左子树的所有节点的值都小于等于根节点的值,右子树的所有节点的值都大于等于根节点的值。因此,中序遍历输出的序列就是一个有序序列。
二叉树排序的平均时间复杂度为O(nlogn),最差时间复杂度为O(n^2)。
其中,n为要排序的数据个数。
在最优情况下,二叉树的高度为logn,每一步比较的时间都是O(1),因此时间复杂度为O(nlogn)。
但是在最坏情况下,如果二叉树退化成为单链表,那么每一次的比较都需要花费O(n)的时间,因此时间复杂度为O(n^2)。
因此,二叉树排序的时间复杂度的平均情况下比较理想,但是最坏情况下会退化成为冒泡排序的时间复杂度。
二叉树排序可应用于以下场景:
二叉树排序可以应用于需要对数据进行快速排序的场景。
public class BinarySortTreeNode {
public int Key { get; set; }
public BinarySortTreeNode Left { get; set; }
public BinarySortTreeNode Right { get; set; }
public BinarySortTreeNode(int key) {
Key = key;
}
public void Insert(int key) {
var tree = new BinarySortTreeNode(key);
if (tree.Key <= Key) {
if (Left == null) {
Left = tree;
}
else {
Left.Insert(key);
}
}
else {
if (Right == null) {
Right = tree;
}
else {
Right.Insert(key);
}
}
}
/// <summary>
/// 中序遍历
/// </summary>
public void InorderTraversal() {
Left?.InorderTraversal();
Console.Write($"{Key} ");
Right?.InorderTraversal();
}
}
public class Program {
public static void Main(string[] args) {
int[] array = { 43, 69, 11, 72, 28, 21, 56, 80, 48, 94, 32, 8 };
BinaryTreeSort(array);
Console.ReadKey();
}
public static void BinaryTreeSort(int[] array) {
var binarySortTreeNode = new BinarySortTreeNode(array[0]);
for (int i = 1; i < array.Length; i++) {
binarySortTreeNode.Insert(array[i]);
}
binarySortTreeNode.InorderTraversal();
}
}