插入排序的简单实现
最简单的排序算法了,每一次j--到对应的值,不会减到0,这个纠结我好久
1 #include "stdafx.h" 2 #include <iostream> 3 #include <vector> 4 using namespace std; 5 6 template <typename Comparable> 7 void insertionSort(vector<Comparable> & a) 8 { 9 int j; 10 for(int p=1 ; p<a.size() ; p++) 11 { 12 Comparable tmp = a[p]; 13 for(j=p ; j>0 && tmp<a[j-1] ; j--) 14 a[j] = a[j-1]; 15 a[j] = tmp; 16 } 17 } 18 int _tmain(int argc, _TCHAR* argv[]) 19 { 20 vector<int> ivec; 21 ivec.push_back(34); 22 ivec.push_back(8); 23 ivec.push_back(64); 24 ivec.push_back(51); 25 ivec.push_back(32); 26 ivec.push_back(21); 27 insertionSort(ivec); 28 for(int i=0 ; i<ivec.size() ; i++) 29 cout<<ivec[i]<<endl; 30 return 0; 31 }
执行结果:
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· 如何编写易于单元测试的代码
· 10年+ .NET Coder 心语,封装的思维:从隐藏、稳定开始理解其本质意义
· .NET Core 中如何实现缓存的预热?
· 从 HTTP 原因短语缺失研究 HTTP/2 和 HTTP/3 的设计差异
· AI与.NET技术实操系列:向量存储与相似性搜索在 .NET 中的实现
· 周边上新:园子的第一款马克杯温暖上架
· Open-Sora 2.0 重磅开源!
· 分享 3 个 .NET 开源的文件压缩处理库,助力快速实现文件压缩解压功能!
· Ollama——大语言模型本地部署的极速利器
· DeepSeek如何颠覆传统软件测试?测试工程师会被淘汰吗?