小编这次要给大家分享的是C++如何使用插入排序对整数数组排序,文章内容丰富,感兴趣的小伙伴可以来了解一下,希望大家阅读完这篇文章之后能够有所收获。
创新互联公司从2013年创立,是专业互联网技术服务公司,拥有项目成都做网站、成都网站设计网站策划,项目实施与项目整合能力。我们以让每一个梦想脱颖而出为使命,1280元彭山做网站,已为上家服务,为彭山各地企业和个人服务,联系电话:028-86922220利用插入排序,对整数数组排序
根据如下插入排序基本思想编程:
例如:
要对3,6,2,4从小到大排序:
1、考虑规模为1的问题,即数字3,一个数显然是有序的;
2、规模为1的问题求解完毕后,加入新的数字6,将其放在3后面,得到序列3,6,从而解决了规模为2的问题;
3、规模为2的问题求解完毕后,加入新的数字2,将其放在3前面,得到序列2,3,6,从而解决了规模为3的问题;
4、规模为3的问题求解完毕后,加入新的数字4,将其放在2和3中间,得到序列2,3,4,6,从而解决了规模为4的问题,排序过程结束。
适用于初学者
#includeusing namespace std; int main() { int i, j, num, temp; int intarray[10] = {2, 5, 1, 9, 10, 0, 4, 8, 7, 6}; int new_intarray[10] = {0}; //第一个数不用排序 new_intarray[0] = intarray[0]; for (i = 1; i < 10; ++i) { //开始排序第i个数,把它储存在一个临时变量 num = intarray[i]; //判断第i个数和第i-1个数的大小,如果比第i-1个数大,则把第i个数放在新数组的第i位 if (num >= new_intarray[i - 1])new_intarray[i] = num; //如果不是的话,依此从大到小交换位置,直到大小顺序符合 else { new_intarray[i] = new_intarray[i - 1]; new_intarray[i - 1] = num; //交换大小顺序错误的两个 for (j = i - 1; j > 0; --j) { if (new_intarray[j] < new_intarray[j - 1]) { temp = new_intarray[j]; new_intarray[j] = new_intarray[j - 1]; new_intarray[j - 1] = temp; } else break; } } } for (i = 0; i < 10; ++i)cout << new_intarray[i] << '\t'; return 0; }
另外有需要云服务器可以了解下创新互联建站www.cdcxhl.com,海内外云服务器15元起步,三天无理由+7*72小时售后在线,公司持有idc许可证,提供“云服务器、裸金属服务器、高防服务器、香港服务器、美国服务器、虚拟主机、免备案服务器”等云主机租用服务以及企业上云的综合解决方案,具有“安全稳定、简单易用、服务可用性高、性价比高”等特点与优势,专为企业上云打造定制,能够满足用户丰富、多元化的应用场景需求。