🏆 作者简介,愚公搬代码 🏆《头衔》:华为云特约编辑,华为云云享专家,华为开发者专家,华为产品云测专家,CSDN博客专家,阿里云专家博主,腾讯云优秀博主,掘金优秀博主,51CTO博客专家等。 🏆《近期荣誉》:2022年CSDN博客之星TOP2,2022年华为云十佳博主等。
🏆《博客内容》:.NET、Java、Python、Go、Node、前端、IOS、Android、鸿蒙、Linux、物联网、网络安全、大数据、人工智能、U3D游戏、小程序等相关领域知识。
🏆🎉欢迎 👍点赞✍评论⭐收藏
排序算法是一种将一组数据按照特定的规则进行排列的方法。排序算法通常用于对数据的处理,使得数据能够更容易地被查找、比较和分析。
下面是常见的11种排序算法:
冒泡排序(Bubble Sort)的基本思想是比较相邻的两个元素,如果顺序不对就交换它们的位置,一轮过后,最大的元素会“冒泡”到序列的末尾,接着对剩下的元素重复以上操作,直至排序完成。
具体实现时,可以使用两个循环,外层循环控制排序的轮次,内层循环控制每轮的比较与交换。每轮结束后,最后一个元素就是当前序列中最大的数,下一轮比较只需要在上一轮排好序的序列中继续比较即可。
冒泡排序的时间复杂度为O(n^2), 其中n是待排序元素的个数。具体来说,当输入数据已经排好序时,冒泡排序的最好情况时间复杂度为O(n),此时只需要进行一轮比较就可以确定所有元素的顺序;当输入数据是倒序排列时,冒泡排序的最坏情况时间复杂度为O(n^2), 此时需要进行n-1轮比较和交换才能完成排序。而在平均情况下,冒泡排序的时间复杂度也是O(n^2)。 因此,冒泡排序算法不适用于大规模数据的排序。
冒泡排序是一种简单的排序算法,适用于数据量较小的情况。它可以应用在以下场景中:
冒泡排序虽然效率较低,但是它的思想简单易懂,适用于一些数据量较小,排序要求不高的场景。
/// <summary>
/// 冒泡排序:是一种用时间换空间的排序方法,时间复杂度最优O(n),最坏O(n^2)
/// </summary>
public class Program {
public static void Main(string[] args) {
int[] array = { 43, 69, 11, 72, 28, 21, 56, 80, 48, 94, 32, 8 };
BubbleSort(array);
ShowSord(array);
Console.ReadKey();
}
private static void ShowSord(int[] array) {
foreach (var num in array) {
Console.Write($"{num} ");
}
Console.WriteLine();
}
public static void BubbleSort(int[] array) {
int swap;
for (int i = 0; i < array.Length; i++) {
for (int j = 0; j < array.Length - i - 1; j++) {
if (array[j] > array[j + 1]) {
swap = array[j];
array[j] = array[j + 1];
array[j + 1] = swap;
}
}
}
}
}
原创声明:本文系作者授权腾讯云开发者社区发表,未经许可,不得转载。
如有侵权,请联系 cloudcommunity@tencent.com 删除。
原创声明:本文系作者授权腾讯云开发者社区发表,未经许可,不得转载。
如有侵权,请联系 cloudcommunity@tencent.com 删除。