久久久久久久999_99精品久久精品一区二区爱城_成人欧美一区二区三区在线播放_国产精品日本一区二区不卡视频_国产午夜视频_欧美精品在线观看免费

 找回密碼
 立即注冊

QQ登錄

只需一步,快速開始

搜索
查看: 3282|回復: 8
打印 上一主題 下一主題
收起左側

分享一個C語言升序排序算法

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

  16.                 max = 0;  //讓 max等于0,進入下一次的內循環
  17.         }
  18. //打印值看一下了
復制代碼


評分

參與人數 1黑幣 +30 收起 理由
admin + 30 共享資料的黑幣獎勵!

查看全部評分

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

使用道具 舉報

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

使用道具 舉報

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

使用道具 舉報

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

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

使用道具 舉報

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

使用道具 舉報

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

使用道具 舉報

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

謝謝解答,明白了。
回復

使用道具 舉報

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

對,是的,可以減一次循環
回復

使用道具 舉報

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

max就不需要定義了吧
回復

使用道具 舉報

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

本版積分規則

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

Powered by 單片機教程網

快速回復 返回頂部 返回列表
主站蜘蛛池模板: 日韩成人专区 | 天天综合久久 | 亚洲综合在线一区 | 97精品国产手机 | 91精品国产91久久久 | 91视频播放 | 免费黄色av网站 | 亚洲精品一区二区三区蜜桃久 | 亚洲视频一区在线观看 | 操操日 | 国产精品久久久久久久久久久久久 | 国产露脸国语对白在线 | 色.com| 国产成人精品综合 | 欧美成人a∨高清免费观看 老司机午夜性大片 | 日本成人久久 | www.久久久 | 国产免费一区二区 | 久久国产精品久久国产精品 | 欧美一区2区三区3区公司 | 日本成人中文字幕 | 久久久久国色av免费观看性色 | 色999视频| 欧美精品中文字幕久久二区 | 日韩一区二区三区四区五区 | 精品久久亚洲 | 精品久久久久久亚洲综合网 | 欧美全黄 | 日韩视频精品 | 国内精品视频一区二区三区 | 精品日韩一区二区 | 日韩福利在线 | 亚洲一区 中文字幕 | 国产在线一区二区三区 | 99久久中文字幕三级久久日本 | 久久久91精品国产一区二区三区 | 黄a网| 国产91在线精品 | 一级a性色生活片久久毛片波多野 | 久久大陆 | 久久这里只有精品首页 |