溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務(wù)條款》

c語言實現(xiàn)選擇排序算法的方法

發(fā)布時間:2020-08-27 11:18:40 來源:億速云 閱讀:254 作者:小新 欄目:編程語言

這篇文章主要介紹c語言實現(xiàn)選擇排序算法的方法,文中介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們一定要看完!

選擇排序算法的基本思想就是依次選出數(shù)組最小的數(shù)放到數(shù)組的前面。在C語言中我們可以使用兩個for循環(huán),首先從數(shù)組的第二個元素開始往后遍歷,找出最小的數(shù)放到第一個位置;再從剩下數(shù)組中找出最小的數(shù)放到第二個位置。以此類推,直到數(shù)組有序。

c語言實現(xiàn)選擇排序算法的方法

選擇排序法的實現(xiàn)原理:

先判斷最小的數(shù)的下標是不是 0,如果不是則說明最小的數(shù)不是第一個元素,則將這個數(shù)與第一個元素互換位置,這樣一輪下來最小的那個數(shù)就被找到并放到了最左邊。

代碼示例:

使用選擇排序法將一組手動輸入的數(shù)據(jù)由小到大進行排序,數(shù)據(jù)分別為 52、36、2、39、56、45、78、92、15、52。

實現(xiàn)代碼:

#include <stdio.h>
int main()
{
    int i,j,t,a[11];    //定義變量及數(shù)組為基本整型
    printf("請輸入10個數(shù):\n");
    for(i=1;i<11;i++)
        scanf("%d",&a[i]);    //從鍵盤中輸入要排序的10個數(shù)字
    for(i=1;i<=9;i++)
        for (j=i+1;j<=10;j++)
            if(a[i]>a[j])    //如果前一個數(shù)比后一個數(shù)大,則利用中間變量t實現(xiàn)兩值互換
            {
                t=a[i];
                a[i]=a[j];
                a[j]=t;
            }
    printf("排序后的順序是:\n");
    for(i=1;i<=10;i++)
        printf("%5d", a[i]);    //輸出排序后的數(shù)組
    printf("\n");
    return 0;
}

輸出:

c語言實現(xiàn)選擇排序算法的方法

代碼說明:

代碼中使用了兩個 for 循環(huán)語句。第一個 for 循環(huán)是確定位置的,該位置是存放每次從待排序數(shù)列中經(jīng)選擇和交換后所選出的最小數(shù)。第二個 for 循環(huán)是實現(xiàn)將確定位置上的數(shù)與后面待排序區(qū)間中的數(shù)進行比較的。

以上是c語言實現(xiàn)選擇排序算法的方法的所有內(nèi)容,感謝各位的閱讀!希望分享的內(nèi)容對大家有幫助,更多相關(guān)知識,歡迎關(guān)注億速云行業(yè)資訊頻道!

向AI問一下細節(jié)

免責聲明:本站發(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)容。

AI