C語言冒泡排序算法代碼詳解
今天我們來用C語言實現(xiàn)一下冒泡排序
首先我們來了解一下什么叫做冒泡排序,冒泡顧名思義把質(zhì)量輕的氣體(如二氧化碳一樣)浮到水面上(如可樂中的二氧化碳),因此冒泡排序的原理就是N個元素在一個周期中,微觀上依次進行兩兩元素的比較,小的元素就被放在前面,大的元素放在后面,以此來進行N-1個周期,來完成冒泡排序。
上文中的一個周期,即外循環(huán),依次進行比較,即內(nèi)循環(huán)。
文字看著很迷糊?沒事兒,上圖
如圖所示,兩兩元素依次進行比較,小的元素往前移動,大的元素往后移動,直至元素順序是升序的形式,即移動了 元素-1 個周期
圖看明白了,還不知道該怎么寫代碼?這就上!
#include <stdio.h> #include <string.h> int main() { int n[9] = { 3,1,6,5,9,7,8,2,4 }; int nums = sizeof(n) / sizeof(int), temp, i; for (i = 1; i < nums ; i++) {//外層循環(huán),表示來回多少次 for (int j = nums - 1; j >= i; j--) //內(nèi)層循環(huán),表示一次來回會對比多少次,注意數(shù)組下標,不要越界 { printf("目前i的值:%d ", i); printf("目前j的值:%d ", j); if (n[j-1] > n[j]) { temp = n[j-1]; n[j-1] = n[j]; n[j] = temp; } printf("該次交換后的結果:"); for (int a = 0; a < nums; a++) { printf("%d ", n[a]); } printf("\n\n"); } } printf("最終交換后的結果:"); for (int a = 0; a < nums; a++) { printf("%d ", n[a]); } printf("\n"); }
代碼同時把每次循環(huán)的結果都進行了輸出,方便觀察排序的結果,同時也可以和圖片進行比較
這里對代碼一些小細節(jié)進行一下說明
首先就是sizeof()函數(shù),這個函數(shù)使用時必須要引用頭文件string.h,他的用法就是計算內(nèi)容的字節(jié),int型占4個字節(jié) n數(shù)組有9個int型的元素,所以占36個字節(jié),除以int型的4字節(jié),就是他的數(shù)組元素個數(shù)。
有人會好奇,明明寫了一個n[9]了,為什么要多此一舉寫一個這個計算表達式,其實在很多時候給的數(shù)組都不會是這么簡單明了的,所以我們最好通過計算來算得數(shù)組元素的個數(shù)。
第二個問題就是,有些小白會卡在這個if判斷語句這里,不知道怎么實現(xiàn)的
if (n[j-1] > n[j]) { temp = n[j-1]; n[j-1] = n[j]; n[j] = temp; }
其實很簡單,就是找一個中間值。我們在這里假設要交換a,b兩數(shù)的值,我們這里就要設置一個中間值,通常設置為temp,把a的值賦值到temp上(然后現(xiàn)在就相當于有兩個a,此刻我們改變a本身的值,temp的值也不會改變),此時我們就可以把b的值賦予到a上面,這一步b對a的值傳輸已經(jīng)結束,最后一步就是把temp的值賦予到b上。大功告成,a,b的值交換成功。
到此這篇關于C語言冒泡排序算法代碼詳解的文章就介紹到這了,更多相關C語言冒泡排序內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關文章希望大家以后多多支持腳本之家!
相關文章
深入探討Linux靜態(tài)庫與動態(tài)庫的詳解(一看就懂)
本篇文章是對Linux靜態(tài)庫與動態(tài)庫進行了詳細的分析介紹,需要的朋友參考下2013-05-05使用Qt/C++實現(xiàn)WGS84,高德GCJ-02與百度BD-09坐標系間相互轉化
這篇文章主要為大家詳細介紹了如何使用Qt實現(xiàn)WGS84、高德GCJ-02與百度BD-09坐標系間相互轉化,文中的示例代碼講解詳細,感興趣的小伙伴可以跟隨小編一起學習一下2023-07-07Visual Studio 2022最新版安裝教程(圖文詳解)
本文主要介紹了Visual Studio 2022最新版安裝教程,文中通過示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下2022-01-01詳談C與C++的函數(shù)聲明中省略參數(shù)的不同意義
下面小編就為大家分享一篇詳談C與C++的函數(shù)聲明中省略參數(shù)的不同意義,具有非常好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧2017-11-11