排序算法复习(2)-- 选择排序

选择排序法的思想是,每次选择数组中最小的一位。实现起来只需要几行代码,时间复杂度是O(N^2)。 

复制代码
 1 public static void SelectedSort(string[] datalist)
 2         {
 3             int minIndex;
 4             for (int i = 0; i <= datalist.Length - 2; i++)//默认从小到大排序,遍历下标,若存在比当前基准下标小的,交换数据,再与下一位比较
 5             {
 6                 minIndex = i;
 7                 for (int j = i + 1; j <= datalist.Length - 1; j++)
 8                 {
 9                     if (datalist[i].CompareTo(datalist[j]) > 0)
10                         minIndex = j;
11                 }
12                 if (minIndex != i)
13                 {
14                     string temp = datalist[i];
15                     datalist[i] = datalist[minIndex];
16                     datalist[minIndex] = temp;
17                 }
18             }
19         }
复制代码

 

使用

1 string[] a = new string[] { "khlin", "hzluo", "jjguo", "hhchen", "jxhan", "lxiao", "jsxiao", "wwang", "lsxie", "lwang" };
2             SelectedSort(a);
3             foreach(string stra in a)
4                 Console.Write("{0}, ",stra);
5             Console.WriteLine();

结果

posted @   kingsleylam  阅读(279)  评论(0编辑  收藏  举报
编辑推荐:
· go语言实现终端里的倒计时
· 如何编写易于单元测试的代码
· 10年+ .NET Coder 心语,封装的思维:从隐藏、稳定开始理解其本质意义
· .NET Core 中如何实现缓存的预热?
· 从 HTTP 原因短语缺失研究 HTTP/2 和 HTTP/3 的设计差异
阅读排行:
· 分享一个免费、快速、无限量使用的满血 DeepSeek R1 模型,支持深度思考和联网搜索!
· 使用C#创建一个MCP客户端
· ollama系列1:轻松3步本地部署deepseek,普通电脑可用
· 基于 Docker 搭建 FRP 内网穿透开源项目(很简单哒)
· 按钮权限的设计及实现
点击右上角即可分享
微信分享提示