找回密碼
 立即注冊

QQ登錄

只需一步,快速開始

搜索
查看: 3320|回復(fù): 8
打印 上一主題 下一主題
收起左側(cè)

分享一個(gè)C語言升序排序算法

[復(fù)制鏈接]
跳轉(zhuǎn)到指定樓層
樓主
ID:632160 發(fā)表于 2021-8-2 19:07 | 只看該作者 回帖獎(jiǎng)勵(lì) |倒序?yàn)g覽 |閱讀模式
目的,用最少的代碼,干最大的事,歡迎在評論區(qū)曬出自己的最少代碼量的排序程序
  1. int temp = 0, max = 0;  //定義兩個(gè)中間變量
  2.         int arr[] = { 0,5,3,9,1,2,4,6,7,8,978,45,34,22 };  //要排序的數(shù)組
  3.         for (int i = 0; i < sizeof(arr) / sizeof(arr[0]); i++) //外循環(huán)次數(shù)要小于數(shù)組長度
  4.         {
  5.                 for (int j = 0; j < (sizeof(arr) / sizeof(arr[0])) - i; j++)  //
  6.                 {
  7.                         if (arr[j] >= max)    //找到每次循環(huán)的中的最大數(shù)
  8.                         {
  9.                                 max = arr[j];     //記錄最大數(shù)
  10.                                 temp = j;         //記錄產(chǎn)生最大數(shù),位于數(shù)組的位置
  11.                         }
  12.                 }
  13.                 max = arr[sizeof(arr) / sizeof(arr[0]) - i - 1];  //將數(shù)組最后一個(gè)值,臨時(shí)賦值給
  14.                 arr[sizeof(arr) / sizeof(arr[0]) - i - 1] = arr[temp];  // 讓數(shù)組最后一個(gè)值,等于在內(nèi)循環(huán)中找到的最大值
  15.                 arr[temp] = max;    //在內(nèi)循環(huán)中找到的最大值的位置等于 MAX

  16.                 max = 0;  //讓 max等于0,進(jìn)入下一次的內(nèi)循環(huán)
  17.         }
  18. //打印值看一下了
復(fù)制代碼


評分

參與人數(shù) 1黑幣 +30 收起 理由
admin + 30 共享資料的黑幣獎(jiǎng)勵(lì)!

查看全部評分

分享到:  QQ好友和群QQ好友和群 QQ空間QQ空間 騰訊微博騰訊微博 騰訊朋友騰訊朋友
收藏收藏3 分享淘帖 頂 踩
回復(fù)

使用道具 舉報(bào)

沙發(fā)
ID:8222 發(fā)表于 2021-8-2 19:33 | 只看該作者
謝謝分享,這代碼很實(shí)用!
回復(fù)

使用道具 舉報(bào)

板凳
ID:8222 發(fā)表于 2021-8-2 19:40 | 只看該作者
for (int i = 0; i < sizeof(arr) / sizeof(arr[0]); i++) //外循環(huán)次數(shù)要小于數(shù)組長度
請賜教sizeof(arr[0])什么意思?而不是 for (int i = 0; i < sizeof(arr) ; i++) 。
回復(fù)

使用道具 舉報(bào)

地板
ID:632160 發(fā)表于 2021-8-3 06:10 | 只看該作者
溫xyz 發(fā)表于 2021-8-2 19:40
for (int i = 0; i < sizeof(arr) / sizeof(arr[0]); i++) //外循環(huán)次數(shù)要小于數(shù)組長度
請賜教sizeof(arr ...

sizeof(arr)是獲取數(shù)組的總字節(jié)長度,sizeof(arr[0])是獲取數(shù)組中一位的字節(jié)長度。用總字節(jié)長度/一位字節(jié)長度。得出的結(jié)果就是。數(shù)組的長度。
回復(fù)

使用道具 舉報(bào)

5#
ID:386001 發(fā)表于 2021-8-3 09:17 | 只看該作者
int temp = 0, max = 0;  //定義兩個(gè)中間變量
int arr[] = { 0,5,3,9,1,2,4,6,7,8,978,45,34,22 };  //要排序的數(shù)組
for (int i = 0; i < sizeof(arr) / sizeof(arr[0]); i++) //外循環(huán)次數(shù)要小于數(shù)組長度
{
        for (int j = 0; j < (sizeof(arr) / sizeof(arr[0])) - i; j++)  //
        {
                if (arr[j] > arr[j+1] )    //相鄰數(shù)兩兩對比,如前邊大于后邊,則交換
                {
                        temp = arr[j];  
                        arr[j]= arr[j+1];  
                        arr[j+1] = temp ;
                }
    }
}
回復(fù)

使用道具 舉報(bào)

6#
ID:936280 發(fā)表于 2021-8-3 10:50 | 只看該作者
挺好的,判斷個(gè)數(shù)的用關(guān)鍵字sizeof給簡化,第二個(gè)for中的可以這樣寫   j < sizeof(arr) / sizeof(arr[0]) - i-1
最大的數(shù)已經(jīng)到最后一個(gè)位置上,就可以減少程序運(yùn)行的時(shí)間了
回復(fù)

使用道具 舉報(bào)

7#
ID:8222 發(fā)表于 2021-8-3 12:00 | 只看該作者
一入極客深似海 發(fā)表于 2021-8-3 06:10
sizeof(arr)是獲取數(shù)組的總字節(jié)長度,sizeof(arr[0])是獲取數(shù)組中一位的字節(jié)長度。用總字節(jié)長度/一位字節(jié) ...

謝謝解答,明白了。
回復(fù)

使用道具 舉報(bào)

8#
ID:632160 發(fā)表于 2021-8-4 16:36 | 只看該作者
洛倫茲力量 發(fā)表于 2021-8-3 10:50
挺好的,判斷個(gè)數(shù)的用關(guān)鍵字sizeof給簡化,第二個(gè)for中的可以這樣寫   j < sizeof(arr) / sizeof(arr[0]) - ...

對,是的,可以減一次循環(huán)
回復(fù)

使用道具 舉報(bào)

9#
ID:632160 發(fā)表于 2021-8-4 16:37 | 只看該作者
sustlixin 發(fā)表于 2021-8-3 09:17
int temp = 0, max = 0;  //定義兩個(gè)中間變量
int arr[] = { 0,5,3,9,1,2,4,6,7,8,978,45,34,22 };  //要 ...

max就不需要定義了吧
回復(fù)

使用道具 舉報(bào)

您需要登錄后才可以回帖 登錄 | 立即注冊

本版積分規(guī)則

手機(jī)版|小黑屋|51黑電子論壇 |51黑電子論壇6群 QQ 管理員QQ:125739409;技術(shù)交流QQ群281945664

Powered by 單片機(jī)教程網(wǎng)

快速回復(fù) 返回頂部 返回列表