C++如何使用插入排序?qū)φ麛?shù)數(shù)組排序-創(chuàng)新互聯(lián)

小編這次要給大家分享的是C++如何使用插入排序?qū)φ麛?shù)數(shù)組排序,文章內(nèi)容豐富,感興趣的小伙伴可以來了解一下,希望大家閱讀完這篇文章之后能夠有所收獲。

創(chuàng)新互聯(lián)公司從2013年創(chuàng)立,是專業(yè)互聯(lián)網(wǎng)技術(shù)服務(wù)公司,擁有項(xiàng)目成都做網(wǎng)站、成都網(wǎng)站設(shè)計(jì)網(wǎng)站策劃,項(xiàng)目實(shí)施與項(xiàng)目整合能力。我們以讓每一個(gè)夢(mèng)想脫穎而出為使命,1280元彭山做網(wǎng)站,已為上家服務(wù),為彭山各地企業(yè)和個(gè)人服務(wù),聯(lián)系電話:028-86922220

利用插入排序,對(duì)整數(shù)數(shù)組排序

根據(jù)如下插入排序基本思想編程:

  • 一個(gè)數(shù)顯然是有序的,因此規(guī)模為1的排序問題能夠求解;
  • 如果能夠?yàn)閚-1個(gè)數(shù)排序,那么當(dāng)有n個(gè)數(shù)時(shí),只需先將前n-1個(gè)數(shù)排好序,再將最后一個(gè)數(shù)插入前面這n-1個(gè)有序數(shù)列中的合適位置即可。
     

例如:

要對(duì)3,6,2,4從小到大排序:

1、考慮規(guī)模為1的問題,即數(shù)字3,一個(gè)數(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};
  //第一個(gè)數(shù)不用排序
  new_intarray[0] = intarray[0];
  for (i = 1; i < 10; ++i) {
    //開始排序第i個(gè)數(shù),把它儲(chǔ)存在一個(gè)臨時(shí)變量
    num = intarray[i];
    //判斷第i個(gè)數(shù)和第i-1個(gè)數(shù)的大小,如果比第i-1個(gè)數(shù)大,則把第i個(gè)數(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;
      //交換大小順序錯(cuò)誤的兩個(gè)
      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;
}

另外有需要云服務(wù)器可以了解下創(chuàng)新互聯(lián)建站bm7419.com,海內(nèi)外云服務(wù)器15元起步,三天無理由+7*72小時(shí)售后在線,公司持有idc許可證,提供“云服務(wù)器、裸金屬服務(wù)器、高防服務(wù)器、香港服務(wù)器、美國(guó)服務(wù)器、虛擬主機(jī)、免備案服務(wù)器”等云主機(jī)租用服務(wù)以及企業(yè)上云的綜合解決方案,具有“安全穩(wěn)定、簡(jiǎn)單易用、服務(wù)可用性高、性價(jià)比高”等特點(diǎn)與優(yōu)勢(shì),專為企業(yè)上云打造定制,能夠滿足用戶豐富、多元化的應(yīng)用場(chǎng)景需求。

網(wǎng)頁題目:C++如何使用插入排序?qū)φ麛?shù)數(shù)組排序-創(chuàng)新互聯(lián)
文章分享:http://bm7419.com/article40/hcseo.html

成都網(wǎng)站建設(shè)公司_創(chuàng)新互聯(lián),為您提供網(wǎng)站導(dǎo)航、手機(jī)網(wǎng)站建設(shè)域名注冊(cè)、響應(yīng)式網(wǎng)站動(dòng)態(tài)網(wǎng)站、營(yíng)銷型網(wǎng)站建設(shè)

廣告

聲明:本網(wǎng)站發(fā)布的內(nèi)容(圖片、視頻和文字)以用戶投稿、用戶轉(zhuǎn)載內(nèi)容為主,如果涉及侵權(quán)請(qǐng)盡快告知,我們將會(huì)在第一時(shí)間刪除。文章觀點(diǎn)不代表本網(wǎng)站立場(chǎng),如需處理請(qǐng)聯(lián)系客服。電話:028-86922220;郵箱:631063699@qq.com。內(nèi)容未經(jīng)允許不得轉(zhuǎn)載,或轉(zhuǎn)載時(shí)需注明來源: 創(chuàng)新互聯(lián)

網(wǎng)站建設(shè)網(wǎng)站維護(hù)公司