中文字幕av专区_日韩电影在线播放_精品国产精品久久一区免费式_av在线免费观看网站

溫馨提示×

溫馨提示×

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

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

c語言中選擇排序和冒泡排序的用法

發布時間:2020-07-03 11:34:13 來源:億速云 閱讀:197 作者:Leah 欄目:編程語言

這篇文章運用簡單易懂的例子給大家介紹c語言中選擇排序和冒泡排序的用法,代碼非常詳細,感興趣的小伙伴們可以參考借鑒,希望對大家能有所幫助。

對于選擇排序,首先理解排序的思想。給定一個數組,這種思想首先假定數組的首元素為最大或者最小的。此時就要利用3個變量表示元素的下標。一個表示當前,一個表示找到的最大或者最小的下標,一個用于存放每次循環中最大值的下標。在掌握了程序的基本思想之后,再進行排序。找到最大的下標后賦給每次除非的那個最大的下標。找到之后判斷所假設的當前值是否為此次循環的最大值,如果不是,就交換最大 與當前的值,從而將數組以一定的順序排放,最后寫一個循環將結果輸出。代碼不是很難,所以我就逐步講解了,只是附上代碼,不懂的可以給我留言,我給大家講解或者有什么不好的地方,我也好修正。

#include<stdio.h>
void main()//主函數
{
   int a[10];
   int i,j,w;
   printf("請輸入10個數字: \n");
    for(i=0;i<10;i++)
   scanf("%d",&a[i]);
    for(i=0;i<10;i++)
{
     for(j=0;j<10;j++)
     if(a[i]<a[j])//進行比較
//比較后進行交換
{
  w=a[i];
         a[i]=a[j];
           a[j]=w;
}
  }
printf("排序后:\n");
        for(i=0;i<10;i++)
            printf("%4d",a[i]);
              printf("\n");
}

結果展示:

c語言中選擇排序和冒泡排序的用法

接下來是冒泡排序,這個是C語言中最常用的算法之一,因為這個比較容易理解,多數人在他們要進行排序的時候首先使用的就是這個算法。這個算法比較容易理解。對于冒泡排序,主要采用的是相鄰數兩兩進行比較的思想。如果后一個比前一個大或者小,則將其調換位置,直至所有的數都比較完。如果給定一個大小為n的數組,那么需要比較n-1趟,每一趟比較n-1-i次 ,i 表示上次循環中已經比較完的下標。寫兩個循環判斷,如需交換則進行交換,如果不需要交換則進行下兩個數的比較,直到所有的數比較完。最后,用一個循環將排序完成后的數全部輸出。代碼如下:

#include<stdio.h>
#define N 10
void main()
{
   int a[10];
   int i,j,t;
   printf("請輸入10個數字: \n");
    for(i=0;i<10;i++)
   scanf("%d",&a[i]);
//使用兩層循環
    for(i=0;i<N-1;i++)
{
     for(j=i+1;j<N-(i+1);j++)
     if(a[j]<a[j+1])//比較大小
{
  t=a[j];
         a[j]=a[j+1];
           a[j+1]=t;
}
}
printf("排序后:\n");
        for(i=0;i<10;i++)
            printf("%4d",a[i]);
              printf("\n");
}

結果:

c語言中選擇排序和冒泡排序的用法

結論淺說:

對于選擇排序的分析是很簡單的,輸入的規模由數組元素決定,基本操作是鍵值比較A[j]<A[min]。因此,對于任何輸入來說,選擇排序都是一個O(n^2)的算法。因此,這個實驗的時間復雜度為O(100),空間復雜度為O(10)。然而,鍵的交換次數僅為O(n),或者更精確一點,是n-1次(i循環每重復一次執行一次交換)。這個特性使得選擇排序優于許多其他的排序算法。

冒泡排序就是相鄰兩個數相比較,大數就沉底(或者小數上浮的過程),總共進行了n-1次比較和交換。上面的冒泡算法為了便于算法的實現,所以考慮只使用一個一維數組來存放10個整型數據。排序過程中數據始終在這個數組中(原地操作,不占用額外的空間)。所以該算法的時間復雜度為O(n-1),空間復雜度為O(1)。

關于c語言中選擇排序和冒泡排序的用法就分享到這里了,希望以上內容可以對大家有一定的幫助,可以學到更多知識。如果覺得文章不錯,可以把它分享出去讓更多的人看到。

向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

AI

都兰县| 汕头市| 平罗县| 靖宇县| 嘉荫县| 巴楚县| 长垣县| 平利县| 湘潭市| 宿州市| 青龙| 进贤县| 瓮安县| 舒城县| 库尔勒市| 淮安市| 平阴县| 华宁县| 洛川县| 赞皇县| 绥芬河市| 巴彦县| 隆尧县| 泰和县| 公主岭市| 新余市| 高邑县| 达州市| 丰城市| 乌恰县| 博罗县| 通辽市| 蒙自县| 天长市| 桐梓县| 丰县| 堆龙德庆县| 鹤山市| 云阳县| 镇沅| 信丰县|