您好,登錄后才能下訂單哦!
小編這次要給大家分享的是C++如何使用插入排序?qū)φ麛?shù)數(shù)組排序,文章內(nèi)容豐富,感興趣的小伙伴可以來了解一下,希望大家閱讀完這篇文章之后能夠有所收獲。
利用插入排序,對整數(shù)數(shù)組排序
根據(jù)如下插入排序基本思想編程:
例如:
要對3,6,2,4從小到大排序:
1、考慮規(guī)模為1的問題,即數(shù)字3,一個數(shù)顯然是有序的;
2、規(guī)模為1的問題求解完畢后,加入新的數(shù)字6,將其放在3后面,得到序列3,6,從而解決了規(guī)模為2的問題;
3、規(guī)模為2的問題求解完畢后,加入新的數(shù)字2,將其放在3前面,得到序列2,3,6,從而解決了規(guī)模為3的問題;
4、規(guī)模為3的問題求解完畢后,加入新的數(shù)字4,將其放在2和3中間,得到序列2,3,4,6,從而解決了規(guī)模為4的問題,排序過程結(jié)束。
適用于初學(xué)者
#include <iostream> using 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}; //第一個數(shù)不用排序 new_intarray[0] = intarray[0]; for (i = 1; i < 10; ++i) { //開始排序第i個數(shù),把它儲存在一個臨時變量 num = intarray[i]; //判斷第i個數(shù)和第i-1個數(shù)的大小,如果比第i-1個數(shù)大,則把第i個數(shù)放在新數(shù)組的第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; }
看完這篇關(guān)于C++如何使用插入排序?qū)φ麛?shù)數(shù)組排序的文章,如果覺得文章內(nèi)容寫得不錯的話,可以把它分享出去給更多人看到。
免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點不代表本網(wǎng)站立場,如果涉及侵權(quán)請聯(lián)系站長郵箱:is@yisu.com進行舉報,并提供相關(guān)證據(jù),一經(jīng)查實,將立刻刪除涉嫌侵權(quán)內(nèi)容。