91超碰碰碰碰久久久久久综合_超碰av人澡人澡人澡人澡人掠_国产黄大片在线观看画质优化_txt小说免费全本

溫馨提示×

溫馨提示×

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

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

怎么在C語言中基于分治法實現歸并排序

發布時間:2021-05-27 18:23:22 來源:億速云 閱讀:159 作者:Leah 欄目:編程語言

這篇文章給大家介紹怎么在C語言中基于分治法實現歸并排序,內容非常詳細,感興趣的小伙伴們可以參考借鑒,希望對大家能有所幫助。

歸并排序的基本思想:

將兩個及其以上的有序表合并為一張有序表,把待排序序列通過分治法分為若干個有序子序列,然后每兩個子序列合并為一個子序列,經過多次合并后整合為一張有序表。

排序過程如圖:

怎么在C語言中基于分治法實現歸并排序

代碼如下:

#include "stdio.h"
#define MAX 100
int is1[MAX],is2[MAX];//原數組is1,臨時空間數組is2
void merge(int low,int mid,int high){
  int i=low,j=mid+1,k=low;
  while(i<=mid&&j<=high)
    if(is1[i]<is1[j])
      is2[k++]=is1[i++];
    else
      is2[k++]=is1[j++];
  while(i<=mid)
    is2[k++]=is1[i++];
  while (j<=high)
    is2[k++]=is1[j++];
  for ( i = low; i <=high ; i++) {
    is1[i]=is2[i];
    printf("%5d",is1[i]);
  }
  printf("\n");
}
 
void mergeSort(int a, int b){
  if(a<b){
    int mid=(a+b)/2;
    mergeSort(a,mid);
    mergeSort(mid+1,b);
    merge(a,mid,b);
  }
}
 
void main(){
  int i,n;
  printf("請輸入元素個數:");
  scanf("%d",&n);
  printf("請依次輸入每個元素:\n");
  for ( i = 1; i <=n ; ++i) {
    scanf("%d",&is1[i]);
  }
  mergeSort(1,n);
  printf("排序后的序列為:\n");
  for ( i = 1; i <=n ; ++i) {
    printf("%4d",is1[i]);
  }
}

關于怎么在C語言中基于分治法實現歸并排序就分享到這里了,希望以上內容可以對大家有一定的幫助,可以學到更多知識。如果覺得文章不錯,可以把它分享出去讓更多的人看到。

向AI問一下細節

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

AI

舒兰市| 双江| 林甸县| 平度市| 蓝田县| 兴隆县| 丰宁| 张家口市| 都兰县| 阳朔县| 建平县| 雷山县| 江源县| 贵阳市| 溧水县| 咸宁市| 镇宁| 芜湖县| 内乡县| 新巴尔虎右旗| 垦利县| 弋阳县| 舞阳县| 湘潭县| 渭南市| 筠连县| 登封市| 南阳市| 印江| 海口市| 于都县| 桦川县| 门源| 宁安市| 五峰| 和平县| 化德县| 高陵县| 兴隆县| 苍梧县| 丹巴县|