欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

C語(yǔ)言實(shí)現(xiàn)數(shù)組元素排序方法詳解

 更新時(shí)間:2023年02月11日 10:45:50   作者:Elanie1024  
這篇文章主要為大家介紹了C語(yǔ)言算法練習(xí)中數(shù)組元素排序的實(shí)現(xiàn)方法,文中的示例代碼講解詳細(xì),對(duì)我們學(xué)習(xí)C語(yǔ)言有一定幫助,需要的可以參考一下

前言

在實(shí)際開(kāi)發(fā)中,有很多場(chǎng)景需要我們將數(shù)組元素按照從大到?。ɑ蛘邚男〉酱螅┑捻樞蚺帕?,這樣在查閱數(shù)據(jù)時(shí)會(huì)更加直觀,例如:

  • 一個(gè)保存了班級(jí)學(xué)號(hào)的數(shù)組,排序后更容易分區(qū)好學(xué)生和壞學(xué)生;
  • 一個(gè)保存了商品單價(jià)的數(shù)組,排序后更容易看出它們的性價(jià)比。

對(duì)數(shù)組元素進(jìn)行排序的方法有很多種,比如冒泡排序、歸并排序、選擇排序、插入排序、快速排序等,其中最經(jīng)典最需要掌握的是「冒泡排序」。

以從小到大排序?yàn)槔芭菖判虻恼w思想是這樣的:

  • 從數(shù)組頭部開(kāi)始,不斷比較相鄰的兩個(gè)元素的大小,讓較大的元素逐漸往后移動(dòng)(交換兩個(gè)元素的值),直到數(shù)組的末尾。經(jīng)過(guò)第一輪的比較,就可以找到最大的元素,并將它移動(dòng)到最后一個(gè)位置。
  • 第一輪結(jié)束后,繼續(xù)第二輪。仍然從數(shù)組頭部開(kāi)始比較,讓較大的元素逐漸往后移動(dòng),直到數(shù)組的倒數(shù)第二個(gè)元素為止。經(jīng)過(guò)第二輪的比較,就可以找到次大的元素,并將它放到倒數(shù)第二個(gè)位置。
  • 以此類推,進(jìn)行 n-1(n 為數(shù)組長(zhǎng)度)輪“冒泡”后,就可以將所有的元素都排列好。

整個(gè)排序過(guò)程就好像氣泡不斷從水里冒出來(lái),最大的先出來(lái),次大的第二出來(lái),最小的最后出來(lái),所以將這種排序方式稱為冒泡排序(Bubble Sort)。

下面我們以“3 2 4 1”為例對(duì)冒泡排序進(jìn)行說(shuō)明。

第一輪 排序過(guò)程

3 2 4 1 (最初)

2 3 4 1 (比較3和2,交換)

2 3 4 1 (比較3和4,不交換)

2 3 1 4 (比較4和1,交換)

第一輪結(jié)束,最大的數(shù)字 4 已經(jīng)在最后面,因此第二輪排序只需要對(duì)前面三個(gè)數(shù)進(jìn)行比較。

第二輪 排序過(guò)程

2 3 1 4 (第一輪排序結(jié)果)

2 3 1 4 (比較2和3,不交換)

2 1 3 4 (比較3和1,交換)

第二輪結(jié)束,次大的數(shù)字 3 已經(jīng)排在倒數(shù)第二個(gè)位置,所以第三輪只需要比較前兩個(gè)元素。

第三輪 排序過(guò)程

2 1 3 4 (第二輪排序結(jié)果)

1 2 3 4 (比較2和1,交換)

至此,排序結(jié)束。

算法總結(jié)及實(shí)現(xiàn)

對(duì)擁有 n 個(gè)元素的數(shù)組 R[n] 進(jìn)行 n-1 輪比較。

第一輪,逐個(gè)比較 (R[1], R[2]), (R[2], R[3]), (R[3], R[4]), ……. (R[N-1], R[N]),最大的元素被移動(dòng)到 R[n] 上。

第二輪,逐個(gè)比較 (R[1], R[2]), (R[2], R[3]), (R[3], R[4]), ……. (R[N-2], R[N-1]),次大的元素被移動(dòng)到 R[n-1] 上。

以此類推,直到整個(gè)數(shù)組從小到大排序。

具體的代碼實(shí)現(xiàn)如下所示:

#include<stdio.h>
intmain(){
int nums[10]={4,5,2,10,7,1,8,3,6,9};
int i, j, temp;
//冒泡排序算法:進(jìn)行 n-1 輪比較
for(i=0; i<10-1; i++){
//每一輪比較前 n-1-i 個(gè),也就是說(shuō),已經(jīng)排序好的最后 i 個(gè)不用比較
for(j=0; j<10-1-i; j++){
if(nums[j]> nums[j+1]){
                temp = nums[j];
                nums[j]= nums[j+1];
                nums[j+1]= temp;
}
}
}
//輸出排序后的數(shù)組
for(i=0; i<10; i++){
printf("%d ", nums[i]);
}
printf("\n");
return0;
}

運(yùn)行結(jié)果:

1 2 3 4 5 6 7 8 9 10

優(yōu)化算法

上面的算法是大部分教材中提供的算法,其中有一點(diǎn)是可以優(yōu)化的:當(dāng)比較到第 i 輪的時(shí)候,如果剩下的元素已經(jīng)排序好了,那么就不用再繼續(xù)比較了,跳出循環(huán)即可,這樣就減少了比較的次數(shù),提高了執(zhí)行效率。

未經(jīng)優(yōu)化的算法一定會(huì)進(jìn)行 n-1 輪比較,經(jīng)過(guò)優(yōu)化的算法最多進(jìn)行 n-1 輪比較,高下立判。

優(yōu)化后的算法實(shí)現(xiàn)如下所示:

#include<stdio.h>
intmain(){
int nums[10]={4,5,2,10,7,1,8,3,6,9};
int i, j, temp, isSorted;
//優(yōu)化算法:最多進(jìn)行 n-1 輪比較
for(i=0; i<10-1; i++){
        isSorted =1;//假設(shè)剩下的元素已經(jīng)排序好了
for(j=0; j<10-1-i; j++){
if(nums[j]> nums[j+1]){
                temp = nums[j];
                nums[j]= nums[j+1];
                nums[j+1]= temp;
                isSorted =0;//一旦需要交換數(shù)組元素,就說(shuō)明剩下的元素沒(méi)有排序好
}
}
if(isSorted)break;//如果沒(méi)有發(fā)生交換,說(shuō)明剩下的元素已經(jīng)排序好了
}
for(i=0; i<10; i++){
printf("%d ", nums[i]);
}
printf("\n");
return0;
}

我們額外設(shè)置了一個(gè)變量 isSorted,用它作為標(biāo)志,值為“真”表示剩下的元素已經(jīng)排序好了,值為“假”表示剩下的元素還未排序好。

每一輪比較之前,我們預(yù)先假設(shè)剩下的元素已經(jīng)排序好了,并將 isSorted 設(shè)置為“真”,一旦在比較過(guò)程中需要交換元素,就說(shuō)明假設(shè)是錯(cuò)的,剩下的元素沒(méi)有排序好,于是將 isSorted 的值更改為“假”。

每一輪循環(huán)結(jié)束后,通過(guò)檢測(cè) isSorted 的值就知道剩下的元素是否排序好。

到此這篇關(guān)于C語(yǔ)言實(shí)現(xiàn)數(shù)組元素排序方法詳解的文章就介紹到這了,更多相關(guān)C語(yǔ)言數(shù)組元素排序內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!

相關(guān)文章

  • C語(yǔ)言實(shí)現(xiàn)通訊錄功能

    C語(yǔ)言實(shí)現(xiàn)通訊錄功能

    這篇文章主要為大家詳細(xì)介紹了C語(yǔ)言實(shí)現(xiàn)通訊錄功能,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2018-02-02
  • C++ boost::asio編程-同步TCP詳解及實(shí)例代碼

    C++ boost::asio編程-同步TCP詳解及實(shí)例代碼

    這篇文章主要介紹了C++ boost::asio編程-同步TCP詳解及實(shí)例代碼的相關(guān)資料,需要的朋友可以參考下
    2016-11-11
  • C++中的引用與高級(jí)函數(shù)詳解

    C++中的引用與高級(jí)函數(shù)詳解

    這篇文章主要介紹了C++中的引用與高級(jí)函數(shù)詳解,概念:引用是為已存在的變量取了一個(gè)別名,引用和引用的變量共用同一塊內(nèi)存空間,需要的朋友可以參考下
    2023-07-07
  • C/C++中static,const,inline三種關(guān)鍵字詳細(xì)總結(jié)

    C/C++中static,const,inline三種關(guān)鍵字詳細(xì)總結(jié)

    以下是對(duì)C/C++中static,const,inline的三種關(guān)鍵字進(jìn)行了詳細(xì)的分析介紹,需要的朋友可以過(guò)來(lái)參考下
    2013-09-09
  • C語(yǔ)言實(shí)現(xiàn)循環(huán)單鏈表的示例代碼

    C語(yǔ)言實(shí)現(xiàn)循環(huán)單鏈表的示例代碼

    這篇文章主要給大家詳細(xì)介紹了C語(yǔ)言如何實(shí)現(xiàn)循環(huán)單鏈表,文章通過(guò)代碼示例講解的非常詳細(xì),對(duì)我們的學(xué)習(xí)或工作有一定的參考價(jià)值,感興趣的小伙伴跟著小編一起來(lái)看看吧
    2023-08-08
  • C語(yǔ)言實(shí)現(xiàn)繪制余弦曲線

    C語(yǔ)言實(shí)現(xiàn)繪制余弦曲線

    這篇文章主要為大家詳細(xì)介紹了C語(yǔ)言實(shí)現(xiàn)繪制余弦曲線的相關(guān)知識(shí),文中的示例代碼講解詳細(xì),感興趣的小伙伴可以跟隨小編一起學(xué)習(xí)一下
    2024-01-01
  • Qt可視化大屏布局的實(shí)現(xiàn)

    Qt可視化大屏布局的實(shí)現(xiàn)

    數(shù)據(jù)可視化大屏在項(xiàng)目中的使用很常見(jiàn),本文主要介紹了Qt可視化大屏布局的實(shí)現(xiàn),具有一定的參考價(jià)值,感興趣的可以了解一下
    2024-02-02
  • 淺析順序結(jié)構(gòu)存儲(chǔ)的棧

    淺析順序結(jié)構(gòu)存儲(chǔ)的棧

    這篇文章主要介紹了順序結(jié)構(gòu)存儲(chǔ)的棧,有需要的朋友可以參考一下
    2014-01-01
  • C語(yǔ)言實(shí)現(xiàn)飛機(jī)訂票系統(tǒng)

    C語(yǔ)言實(shí)現(xiàn)飛機(jī)訂票系統(tǒng)

    這篇文章主要為大家詳細(xì)介紹了C語(yǔ)言實(shí)現(xiàn)飛機(jī)訂票系統(tǒng),文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2019-12-12
  • 深入學(xué)習(xí)C語(yǔ)言中常見(jiàn)的八大排序

    深入學(xué)習(xí)C語(yǔ)言中常見(jiàn)的八大排序

    排序編程中非?;A(chǔ)的的理論方法,雖然排序的方法多,但是理解起來(lái)并不難,它是最基本的,初學(xué)者一定要掌握的東西。本文給大家介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值
    2021-11-11

最新評(píng)論