大學生新聞網,大學生新聞發布平臺
大學生新聞網
大學生新聞大學生活校園文學大學生村官
社會實踐活動社會實踐經歷社會實踐報告社會實踐總結社會實踐心得
全國排名校友會版軟科排名分類排名本科排名一本排名二本排名專科排名學校地址
求職簡歷職場法則面試技巧職場故事求職招聘大學生就業
英語學習計算機學習電氣工程機械工程經濟管理建筑設計財務會計
申請書證明書檢討書自薦信演講稿心得體會調查報告讀后感求職信推薦信其它范文

C語言歸并排序算法

用歸并排序法對一組數據由小到大進行排序,數據分別為 695、458、362、789、12、 15、163、23、2、986。

實現過程:
(1) 自定義函數 merge(),實現一次歸并排序。
(2) 自定義函數 merge_sort(),實現歸并排序。
(3) 程序代碼如下:

#include <stdio.h>
int merge(int r[],int s[],int x1,int x2,int x3)    //自定義實現一次歸并樣序的函數
{
    int i,j,k;
    i=x1;    //第一部分的開始位置
    j=x2+1;  //第二部分的開始位置
    k=x1;
    while((i<=x2)&&(j<=x3))    //當i和j都在兩個要合并的部分中時
        if(r[i]<=r[j])    //篩選兩部分中較小的元素放到數組s中
        {
            s[k] = r[i];
            i++;
            k++;
        }
        else
        {
            s[k]=r[j];
            j++;
            k++;
        }
        while(i<=x2)    //將x1〜x2范圍內未比較的數順次加到數組r中
            s[k++]=r[i++];
        while(j<=x3) //將x2+l〜x3范圍內未比較的數順次加到數組r中
            s[k++]=r[j++];
    return 0;
}
 
int merge_sort(int r[],int s[],int m,int n)
{
    int p;
    int t[20];
    if(m==n)
        s[m]=r[m];
    else
    {
        p=(m+n)/2;
        merge_sort(r,t,m,p);    //遞歸調用merge_soit()函數將r[m]〜r[p]歸并成有序的t[m]〜t[p]
        merge_sort(r,t,p+1,n);    //遞歸一調用merge_sort()函數將r[p+l]〜r[n]歸并成有序的t[p+l]〜t[n]
        merge(t,s,m,p,n);    //調用函數將前兩部分歸并到s[m]〜s[n】*/
    }
    return 0;
}
 
int main()
{
    int a[11];
    int i;
    printf("請輸入10個數:\n");
    for(i=1;i<=10;i++)
        scanf("%d",&a[i]);    //從鍵盤中輸入10個數
    merge_sort(a,a,1,10);    //調用merge_sort()函數進行歸并排序
    printf("排序后的順序是:\n");
    for(i=1;i<=10;i++)
        printf("%5d",a[i]);    //輸出排序后的數據
    printf("\n");
    return 0;
}
運行結果:
請輸入10個數:
695 458 362 789 12 15 163 23 2 986
排序后的順序是:
2 12 15 23 163 362 458 695 789 986

技術要點:
歸并是將兩個或多個存序記錄序列合并成一個有序序列。歸并方法有多種,一次對兩個有序記錄序列進行歸并,稱為路歸并排序,也有三路歸并排序及多路歸并排序。本實例是二路歸并排序,基本方法如下:

(1) 將 n 個記錄看成是 n 個長度為 1 的有序子表。

(2) 將兩兩相鄰時有序無表進行歸并。

(3) 重復執行步驟 (2) 直到歸并成一個長度為 n 的有序表。
    作者:大學生新聞網    來源:大學生新聞網
    發布時間:2025-03-05    閱讀:
    掃一掃 分享悅讀
  • C語言二分查找算法,折半查找算法
  • 本實例采用二分查找法查找特定關鍵字的元素。要求用戶輸入數組長度,也就是有序表的數據長度,并輸入數組元素和査找的關鍵字。
  • 03-05 關注:0
  • C語言歸并排序算法
  • 用歸并排序法對一組數據由小到大進行排序,數據分別為 695、458、362、789、12、 15、163、23、2、986。
  • 03-05 關注:0
  • C語言選擇排序算法
  • 用選擇排序法對一組數據由小到大進行排序,數據分別為 526、36、2、369、56、45、78、92、125、52。
  • 03-05 關注:0
  • C語言快速排序算法
  • 用快速排序法對一組數據由小到大進行排序,數據分別為 99、45、12、36、69、22、62、 796、4、696。
  • 03-05 關注:0
  • C語言直接插入排序算法
  • 插入排序是把一個記錄插入到已排序的有序序列中,使整個序列在插入該記錄后仍然有序。插入排序中較簡單的種方法是直接插入排序
  • 03-03 關注:3
  • C語言冒泡排序算法
  • 用冒泡排序法對任意輸入的 10 個數按照從小到大的順序進行排序。
  • 03-03 關注:5
  • C語言希爾排序算法
  • 用希爾排序法對一組數據由小到大進行排序,數據分別為 69、56、12、136、3、55、46、 99、88、25。
  • 03-03 關注:3
主站蜘蛛池模板: 五月婷婷丁香网| 欧美性色19p| spoz是什么意思医学| 国产三级观看久久| 日韩电影免费观看| 欧美jlzz18性欧美| 亚洲av无码片vr一区二区三区 | 免费看大美女大黄大色| 成品大香煮伊在2021一| 美村妇真湿夹得我好爽| 丰满熟妇乱又伦| 又黄又爽的视频在线观看| 成人免费看www网址入口| 精品欧洲av无码一区二区三区| 中文字幕乱码中文乱码51精品| 四虎国产精品永久在线| 宅男噜66免费看网站| 爱情岛亚洲论坛在线观看| 99久久人妻精品免费二区| 亚洲日韩中文字幕在线播放 | 久久99国产精品| 午夜成人精品福利网站在线观看| 怡红院免费手机在线观看| 精品一区二区三区中文字幕| china同性基友gay勾外卖| 亚洲欧美综合国产精品一区| 国产精品成人久久久久久久| 日韩精品视频观看| 老师你的兔子好软水好多作文高清| spoz是什么意思医学| 亚洲欧美日韩国产精品一区二区| 怡红院免费手机在线观看| 蜜臀AV在线播放一区二区三区 | 国产亚洲3p无码一区二区| 欧美人和黑人牲交网站上线| 91视频国产91久久久| 亚洲人成影院在线无码按摩店| 国产亚洲色婷婷久久99精品| 男女之间差差差| 久久机热这里只有精品无需| 中文字幕精品一区二区精品|