1035. 插入与归并(25)

6 篇文章 0 订阅

题目:

根据维基百科的定义:

插入排序是迭代算法,逐一获得输入数据,逐步产生有序的输出序列。每步迭代中,算法从输入序列中取出一元素,将之插入有序序列中正确的位置。如此迭代直到全部元素有序。

归并排序进行如下迭代操作:首先将原始序列看成N个只包含1个元素的有序子序列,然后每次迭代归并两个相邻的有序子序列,直到最后只剩下1个有序的序列。

现给定原始序列和由某排序算法产生的中间序列,请你判断该算法究竟是哪种排序算法?

输入格式:

输入在第一行给出正整数N (<=100);随后一行给出原始序列的N个整数;最后一行给出由某排序算法产生的中间序列。这里假设排序的目标序列是升序。数字间以空格分隔。

输出格式:

首先在第1行中输出“Insertion Sort”表示插入排序、或“Merge Sort”表示归并排序;然后在第2行中输出用该排序算法再迭代一轮的结果序列。题目保证每组测试的结果是唯一的。数字间以空格分隔,且行末不得有多余空格。

输入样例1:
10
3 1 2 8 7 5 9 4 6 0
1 2 3 7 8 5 9 4 6 0
输出样例1:
Insertion Sort
1 2 3 5 7 8 9 4 6 0
输入样例2:
10
3 1 2 8 7 5 9 4 0 6
1 3 2 8 5 7 4 9 0 6
输出样例2:
Merge Sort
1 2 3 8 4 5 7 9 0 6

比较坑的就是测试点二:当原序列与序列同为2341时应输出1234

代码如下,仅供参考

#include <cstdio>
#include <iostream>
#include <math.h>
#include <bits/stdc++.h>
#include <algorithm>
using namespace std;

bool cmp(int x, int y)
{
    return x<y;
}
int compare(int a[],int b[],int n)
{
    for(int i = 0 ;i < n ;i++)
    {
        if(a[i] != b[i])
        {
            return 0;
        }
    }
    return 1;
}
int main()
{
   int n;
   cin >> n;
   int a[n],sort_a[n],b[n],flag = 0 ,temp = 0 , sort_type = 0 ,temp1 = 0 , temp2 = 0 ,merge_a[n];
   for(int i = 0 ;i < n ;i++)
   {
       cin >> a[i];
       b[i] = a[i];
       merge_a[i] = a[i];
   }
   for(int i = 0 ; i < n;i++)
   {
       cin >> sort_a[i];
   }

   for(int i = n -1 ; i >= 0 ;i--)
   {
       if(!flag){
       if(a[i] == sort_a[i])
       {
           temp++;
       }else{
          flag = 1;
          i++;
          sort(b,b+n-temp,cmp);
       }
       }else{
         if(b[i] == sort_a[i])
         {
             temp1++;
         }
       }
   }
   if((temp + temp1) == n){
        sort_type = 0;
   if(temp == n)
   {
       int i = 0;
       for(i = 0 ; i < n ;i++)
       {
           if(a[i+1]>=a[i])continue;
           else break;
       }
       temp = n - i - 1;
   }
   if(a[temp1]>b[temp1-1])temp--;
   }else sort_type = 1;
   if(sort_type == 0)
   {
       printf("Insertion Sort\n");
       sort(a,a+n-temp+1,cmp);
       for(int i = 0 ; i < n ;i++)
       {
           if(i == 0)
           {
               printf("%d",a[i]);
           }else{
               printf(" %d",a[i]);
           }
       }
   }else{
       int buchang = 2;
       printf("Merge Sort\n");
       for(int i = 0 ; i < n ;i++)
       {
           for(int j = 0 ; j < n ;)
           {
               if(j + buchang <= n)
               sort(merge_a+j,merge_a+j+buchang,cmp);
               else sort(merge_a+j,merge_a+n,cmp);
               j = j + buchang;
           }
           if(compare(merge_a,sort_a,n) == 1)
           {
               buchang *= 2;
               for(int j = 0 ; j < n ;)
               {
               if(j + buchang <= n)
               sort(merge_a+j,merge_a+j+buchang,cmp);
               else sort(merge_a+j,merge_a+n,cmp);
               j = j + buchang;
               }
               for(int i = 0 ; i < n ;i++)
               {
                if(i == 0)
                {
                    printf("%d",merge_a[i]);
                }else{
                    printf(" %d",merge_a[i]);
                     }
               }
               break;
           }else{
               buchang *= 2;
           }
       }
   }
}

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值