求两个有序数列的合并——分治算法
Posted 剑枫
tags:
篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了求两个有序数列的合并——分治算法相关的知识,希望对你有一定的参考价值。
用分治算法来求一个数组的排序
分治算法:例如:将两个数组a[100]={2,4,5,7,1,2,,3,6}。这个数组排序
先将这个数组分为均两部分得到{2,4,5,7},{1,2,3,6}。
再将{2,4,5,7}分为两部分{2,4},{5,7}。
再分为{2},{4}。
这时一个数就不用排序了,直接输出自己。
简单问题,就可以用二分或者三分来算。
上代码:
#include <bits/stdc++.h> using namespace std; void hebing(int a[],int b,int mid,int c) {int* k=new int [1000]; int i=b,j=mid+1; int u=0; while(i<=mid&&j<=c) { if(a[i]<=a[j]) {k[u++]=a[i];i++;} else { k[u++]=a[j]; j++; } } while(i<=mid){k[u++]=a[i];i++;} while(j<=c){k[u++]=a[j];j++;} for(int i=b,u=0;i<=c;i++,u++) { a[i]=k[u]; } delete[] k; } // 这个hebing函数的具体代码。 void paixu(int a[],int b,int c) //b表示起始位置,c表示终止位置。 { int mid; if(b>=c) return ; mid=(b+c)/2; paixu(a,b,mid); paixu(a,mid+1,c); //构建两个排好序的数组(从起始到中间,从中间到终止) hebing(a,b,mid,c); //将两个分别排好序的数组,整体排序,合二为一,组成一个我们想要的排好序的数组。 } int main() { int n; int a[1000]; cin>>n; for(int i=0;i<n;i++) { cin>>a[i]; } paixu(a,0,n-1); for(int i=0;i<n;i++) cout<<a[i]<<" "; return 0; }
这个代码的运行时间要比sort函数用的时间短。
以上是关于求两个有序数列的合并——分治算法的主要内容,如果未能解决你的问题,请参考以下文章