文章目錄
- 歸并排序
- 一、歸并排序思路
- 二、歸并排序算法模板
- 三、題目
- 代碼
歸并排序
一、歸并排序思路
二、歸并排序算法模板
void merge_sort(int q[], int l, int r)
{if (l >= r) return;int mid = l + r >> 1;//中間值merge_sort(q, l, mid);merge_sort(q, mid + 1, r);int k = 0, i = l, j = mid + 1;while (i <= mid && j <= r)if (q[i] <= q[j]) tmp[k ++ ] = q[i ++ ];else tmp[k ++ ] = q[j ++ ];while (i <= mid) tmp[k ++ ] = q[i ++ ];while (j <= r) tmp[k ++ ] = q[j ++ ];for (i = l, j = 0; i <= r; i ++, j ++ ) q[i] = tmp[j];
}
三、題目
給定你一個長度為 n 的整數數列。
請你使用歸并排序對這個數列按照從小到大進行排序。
并將排好序的數列按順序輸出。
輸入格式
輸入共兩行,第一行包含整數 n。
第二行包含 n 個整數(所有整數均在 1~109 范圍內),表示整個數列。
輸出格式
輸出共一行,包含 n 個整數,表示排好序的數列。
數據范圍
1≤n≤100000
輸入樣例:
5
3 1 2 4 5
輸出樣例:
1 2 3 4 5
代碼
#include<iostream>
using namespace std;const int N=1e6+10;int n;
int q[N],tmp[N];//tmp用來存答案數值,然后重新賦值給q數組 void merge_sort(int q[],int l,int r)
{if(l>=r) return ;int mid=(l+r)/2;merge_sort(q,l,mid),merge_sort(q,mid+1,r);int k=0,i=l,j=mid+1;while(i<=mid&&j<=r){if(q[i]<=q[j])tmp[k++]=q[i++];elsetmp[k++]=q[j++];}while(i<=mid) tmp[k++]=q[i++];while(j<=r)tmp[k++]=q[j++];for(i=l,j=0;i<=r;i++,j++)q[i]=tmp[j];
}int main()
{scanf("%d",&n);for(int i=0;i<n;i++)scanf("%d",&q[i]);merge_sort(q,0,n-1);for(int i=0;i<n;i++)printf("%d",q[i]);return 0;
}