c#选择排序

选择排序思路

  • 将数组分为已排序(前部)和未排序(后部)两部分。初始时已排序部分为空。

  • 在每一轮中,从未排序部分找出最小(或最大)的元素,将其与未排序部分的第一个元素交换。这样,该元素就被放到了已排序部分的末尾。

  • 重复上述过程,直到所有元素都被放入已排序部分。

时空复杂度

  • 时间复杂度:O(n²)(无论数据是否有序,都需要进行 n-1 轮扫描)。

  • 空间复杂度:O(1)(原地排序)。

  • 稳定性:不稳定(例如,交换可能改变相同元素的相对顺序)。

速记套路

思路 新建中间变量,依次比较,找出极值,放入目标位置,比较n轮

套路写法 两层循环 外层轮数 内层寻找 初始索引 记录极值 内层循环外交换

复制代码
 int[] arr = new int[]{ 3,6,2,10,998,23,5};
for (int i = 0; i < arr.Length; i++)
{
    int index = 0;
    for (int j = 1; j < arr.Length-i; j++)
    {
        
        if (arr[index] < arr[j])
        {
             index =j ;                      
        }
    }
    int temp = arr[index];
    arr[index]=arr[arr.Length - 1 - i] ;
    arr[arr.Length - 1 - i]=temp;
}
for (int i = 0; i < arr.Length; i++)
{
    Console.WriteLine(arr[i]);
}
相关推荐
雪豹阿伟2 小时前
4.C# —— 循环语句、break、continue
c#·上位机
两千次2 小时前
webpost
c#
不知名的忻2 小时前
堆排序(Java)
java·数据结构·算法·排序算法
思麟呀2 小时前
在C++基础上理解Csharp-2
开发语言·jvm·c++·c#
薇茗3 小时前
【初阶数据结构】 升沉有序的平仄 排序
c语言·数据结构·算法·排序算法
吴可可1234 小时前
用Bulge保持多段线圆弧连续性
算法·c#
不知名的忻5 小时前
归并排序(Java)
java·算法·排序算法
qq_4312807018 小时前
上位与基恩士PLC通讯工作记录
c#
weixin_4280053021 小时前
C#调用 AI学习从0开始-第1阶段(基础与工具)-第2天Prompt工程基础
人工智能·学习·c#·prompt
咩图1 天前
WPF-VisualStudio-C#-Fluent.Ribbon8.0.0学习
c#·wpf·visual studio