随笔 - 576  文章 - 0  评论 - 62  阅读 - 219万

选择排序

1、思路:对于当前第一个数,假定它是最小的,遍历后面的数,发现比当前数还小的,进行交换,这样就保证了当前第一个为最小的。

2、代码:

复制代码
 1 template <typename T>
 2 void SelectSort(vector<T>& vec)
 3 {
 4     for(int i=0; i< vec.size();i++)
 5     {
 6         T min = vec[i];
 7         for(int j=i+1;j < vec.size();j++)
 8         {
 9             if(vec[j]<min)
10             {                
11                 min = vec[j];
12                 vec[j] = vec[i];
13                 vec[i] = min;
14             }
15         }
16     }
17 }
复制代码

3、上述代码,存在问题:交换上来的元素还可能不是最小的,会导致多次交换。解决办法是,发现更小的之后,不交换,而是记录最小的下标,最后找到最小的下标,然后交换。代码:

复制代码
 1 template <typename T>
 2 void SelectSort_2(vector<T>& vec)
 3 {
 4     for(int i=0; i< vec.size();i++)
 5     {
 6         int index_Min = i;
 7         for(int j=i+1;j < vec.size();j++)
 8         {
 9             if(vec[j]<vec[index_Min])
10             {                
11                 index_Min = j;
12             }
13         }
14 
15         if(index_Min != i)
16         {
17             swap(vec,i,index_Min);
18         }        
19     }
20 }
复制代码

 

posted on   Andy Niu  阅读(273)  评论(0编辑  收藏  举报
编辑推荐:
· AI与.NET技术实操系列:向量存储与相似性搜索在 .NET 中的实现
· 基于Microsoft.Extensions.AI核心库实现RAG应用
· Linux系列:如何用heaptrack跟踪.NET程序的非托管内存泄露
· 开发者必知的日志记录最佳实践
· SQL Server 2025 AI相关能力初探
阅读排行:
· winform 绘制太阳,地球,月球 运作规律
· 震惊!C++程序真的从main开始吗?99%的程序员都答错了
· AI与.NET技术实操系列(五):向量存储与相似性搜索在 .NET 中的实现
· 超详细:普通电脑也行Windows部署deepseek R1训练数据并当服务器共享给他人
· 【硬核科普】Trae如何「偷看」你的代码?零基础破解AI编程运行原理
< 2025年3月 >
23 24 25 26 27 28 1
2 3 4 5 6 7 8
9 10 11 12 13 14 15
16 17 18 19 20 21 22
23 24 25 26 27 28 29
30 31 1 2 3 4 5

点击右上角即可分享
微信分享提示