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]);
}
相关推荐
weixin_5375904513 小时前
《C程序设计语言》练习答案(练习1-13)
c语言·开发语言·c#
a177988771213 小时前
小程序上传图像失败
小程序·c#
JosieBook15 小时前
【C#】C# 所有关键字总结
开发语言·算法·c#
我是唐青枫15 小时前
C#.NET ConcurrentStack<T> 深入解析:无锁栈原理、LIFO 语义与使用边界
网络·c#·.net
黑棠会长16 小时前
ABP框架09.数据安全与合规:审计日志与实体变更追踪
分布式·安全·架构·c#·abp
JMchen12316 小时前
Android NDK开发从入门到实战:解锁应用性能的终极武器
android·开发语言·c++·python·c#·android studio·ndk开发
IT小哥哥呀17 小时前
基于windows的个人/团队的时间管理工具
windows·c#·wpf·时间管理
JosieBook19 小时前
【C#】C# 访问修饰符与类修饰符总结大全
前端·javascript·c#
星夜泊客19 小时前
C# : 引用类型都存在堆上吗
unity·c#
chiwei_hua19 小时前
如何在 Blazor Web 前端中使用 C# 进行数据交互?
前端·c#·交互