zoukankan      html  css  js  c++  java
  • 【算法笔记】B1035 插入与归并

    1035 插入与归并 (25 分)

    根据维基百科的定义:

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

    归并排序进行如下迭代操作:首先将原始序列看成 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

    思路:

    只需要判断是否是插入排序,如果不是插入排序必然是归并排序。

    输出下一次迭代的方法是设置一个flag位,先判断排序是否是目标序列,不管是不是都再迭代一次,最后根据flag判断继续迭代还是终止循环。

    codes:

     1 #include<iostream>
     2 #include<algorithm>
     3 using namespace std;
     4 const int maxn = 101;
     5 int ori[maxn], tempOri[maxn], mid[maxn];
     6 int n;
     7 void print(int a[]){
     8     for(int i = 0; i < n; i++){
     9         cout<<a[i];
    10         if(i < n - 1) cout<<" ";
    11     }
    12 }
    13 bool isSame(int a[], int b[]){
    14     for(int i = 0; i < n; i++){
    15         if(a[i] != b[i]) return false;
    16     }
    17     return true;
    18 }
    19 bool insertSort(){
    20     for(int i = 1; i < n; i++){
    21         bool flag = false;
    22         if(i != 1 && isSame(tempOri,mid)) flag = true;
    23         int t = tempOri[i], j = i;
    24         for(j = i - 1; j >= 0, tempOri[j] > t; j--)
    25             tempOri[j + 1] = tempOri[j];
    26         tempOri[j + 1] = t;
    27         if(flag) return true;
    28     }
    29     return false;
    30 }
    31 void mergeSort(){
    32     bool flag = false;
    33     for(int step = 2; step / 2 < n; step *= 2){
    34         if(step!=2 && isSame(tempOri,mid)) flag = true;
    35         for(int i = 0; i < n; i += step){
    36             sort(tempOri + i, tempOri + min(i + step, n));
    37         }
    38         if(flag) break;
    39     }
    40  }
    41 int main(){
    42     cin>>n;
    43     for(int i = 0; i < n; i++){
    44         cin>>ori[i];
    45         tempOri[i] = ori[i];
    46     }
    47     for(int i = 0; i < n; i++){
    48         cin>>mid[i];
    49     }
    50     if(insertSort()){
    51         cout<<"Insertion Sort"<<endl;
    52         print(tempOri);
    53     }else{
    54         for(int i = 0; i < n; i++){
    55             tempOri[i] = ori[i];
    56         }
    57         mergeSort();
    58         cout<<"Merge Sort"<<endl;
    59         print(tempOri);
    60     }
    61     return 0;
    62 }
  • 相关阅读:
    HDU 5977 Garden of Eden(点分治求点对路径颜色数为K)
    HDU 5828 Rikka with Sequence(线段树区间加开根求和)
    TZOJ 1689 Building A New Barn(求平面上有几个其它点求到n个点的曼哈顿距离最小)
    HDU 5734 Acperience(数学推导)
    POJ 1741 Tree(点分治点对<=k)
    HDU 5723 Abandoned country(kruskal+dp树上任意两点距离和)
    HDU 5988 Coding Contest(最小费用最大流变形)
    TZOJ 1693 Silver Cow Party(最短路+思维)
    TZOJ 4602 高桥和低桥(二分或树状数组+二分)
    TZOJ 2099 Sightseeing tour(网络流判混合图欧拉回路)
  • 原文地址:https://www.cnblogs.com/chunlinn/p/10598322.html
Copyright © 2011-2022 走看看