1089 Insert or Merge (插入排序,相邻归并排序,附模拟实现)

注意点1:判断插入排序不能从头开始判断是否为目标数组,

比如:初始为1 2 3 4 3,目标数组也为1 2 3 4 3,则如果是从头开始推的,则下一步会变成1 2 3 4 3,而下一步应该是 1 2 3 3 4。所以我们应该从第一个无序的位置开始排序。也就是从最后一个3开始排序判断目标数组。

注意点2:题目中的归并排序为相邻归并(递推归并),而非中分归并(递归归并)。

技巧点:排序可以用sort减少思考步骤。

常规模拟版

#include
using namespace std;
int a[110],b[110],c[110];
int n;
bool check(){
    for(int i=0;i0&&c[pos-1]>temp){
            c[pos]=c[pos-1];
            pos--;
        }
        c[pos]=temp;
        if(flag)return 1;
    }
    return 0;
}
void merge(){
    bool flag=0;
    for(int len=2;len<=n;len*=2){
        if(check())flag=1;
        for(int l=0;ltemp;
            while(i<=mid&&j<=r){
                if(c[i]<=c[j])temp.push_back(c[i++]);
                else temp.push_back(c[j++]);
            }
            while(i<=mid)temp.push_back(c[i++]);
            while(j<=r)temp.push_back(c[j++]);
            for(i=l,j=0;i<=r;i++,j++){
                c[i]=temp[j];
            }
        }
        if(flag)return ;
    }
}
int main(){
    cin>>n;
    for(int i=0;i>a[i];
    for(int i=0;i>b[i];
    memcpy(c,a,sizeof a);
    if(insert()){
        cout<<"Insertion Sort"<

sort版 

#include
using namespace std;
int a[110],b[110],c[110];
int n;
bool check(){
    for(int i=0;i>n;
    for(int i=0;i>a[i];
    for(int i=0;i>b[i];
    memcpy(c,a,sizeof a);
    if(insert()){
        cout<<"Insertion Sort"<

你可能感兴趣的:(数据结构,算法,排序算法)