C語言分治法實現(xiàn)歸并排序
本文實例為大家分享了C語言實現(xiàn)歸并排序的具體代碼,供大家參考,具體內(nèi)容如下
歸并排序的基本思想:
將兩個及其以上的有序表合并為一張有序表,把待排序序列通過分治法分為若干個有序子序列,然后每兩個子序列合并為一個子序列,經(jīng)過多次合并后整合為一張有序表。
排序過程如圖:

代碼如下:
#include "stdio.h"
#define MAX 100
int is1[MAX],is2[MAX];//原數(shù)組is1,臨時空間數(shù)組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("請輸入元素個數(shù):");
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]);
}
}
以上就是本文的全部內(nèi)容,希望對大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。
相關(guān)文章
C++ 中使用lambda代替 unique_ptr 的Deleter的方法
這篇文章主要介紹了C++ 中使用lambda代替 unique_ptr 的Deleter的方法,需要的朋友可以參考下2017-04-04
C語言中進(jìn)行大小寫字母轉(zhuǎn)化的示例代碼
C語言標(biāo)準(zhǔn)庫中提供了用于大小寫轉(zhuǎn)換的函數(shù),使得這一操作變得簡單而高效,本文將詳細(xì)介紹如何在C語言中進(jìn)行大小寫字母的轉(zhuǎn)換,包括相關(guān)的函數(shù)和示例代碼,需要的朋友可以參考下2024-03-03
實戰(zhàn)開發(fā)為單片機(jī)的按鍵加一個鎖防止多次觸發(fā)的細(xì)節(jié)
今天小編就為大家分享一篇關(guān)于實戰(zhàn)開發(fā)為單片機(jī)的按鍵加一個鎖防止多次觸發(fā)的細(xì)節(jié),小編覺得內(nèi)容挺不錯的,現(xiàn)在分享給大家,具有很好的參考價值,需要的朋友一起跟隨小編來看看吧2018-12-12
C++ throw關(guān)鍵字實現(xiàn)拋出異常和異常規(guī)范
本文主要介紹了C++ throw關(guān)鍵字實現(xiàn),文中通過示例代碼介紹的非常詳細(xì),具有一定的參考價值,感興趣的小伙伴們可以參考一下2021-08-08

