1035 插入与归并(25 分)

根据维基百科的定义:

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

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

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

输入格式:

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

输出格式:

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

输入样例 1:

  1. 10
  2. 3 1 2 8 7 5 9 4 6 0
  3. 1 2 3 7 8 5 9 4 6 0

输出样例 1:

  1. Insertion Sort
  2. 1 2 3 5 7 8 9 4 6 0

输入样例 2:

  1. 10
  2. 3 1 2 8 7 5 9 4 0 6
  3. 1 3 2 8 5 7 4 9 0 6

输出样例 2:

  1. Merge Sort
  2. 1 2 3 8 4 5 7 9 0 6

PS:

思路:由于这道题排序个数并不多(N<=100),所以我们没必要一定要把这两个排序方法都写出来,我们只需要知道原理,这里我通过STL提供的sort模拟插入和归并排序

测试点:插入排序(测试点0、2、4) 归并排序(测试点1、3、5、6);

详细请看代码及注解

  1. #include<iostream>
  2. #include<algorithm>
  3. using namespace std;
  4. int n;
  5. void insort(int a[], int b[]) {
  6. int key = 0; //当匹配到中间序列时,key置1,下次排序后输出,结束程序就行
  7. for (int i = 2; i <= n; i++) { //插入排序起始为2,结束为n,否则测试点2不通过
  8. sort(a, a + i);
  9. if (key) {
  10. cout << "Insertion Sort" << endl;
  11. cout << a[0];
  12. for (int j = 1; j < n; j++)
  13. cout << " " << a[j];
  14. return;
  15. }
  16. if (equal(a, a + n, b)) //equal是一个比较数组的函数
  17. key = 1;
  18. }
  19. }
  20. void mesort(int a[], int b[]) {
  21. int key = 0;
  22. for (int i = 2;; i *= 2) { //这里不给结束条件,是因为当i>n时还要进行一次排序
  23. for (int j = 0; j < n; j += i) {
  24. sort(a + j, a + (j + i < n ? j + i : n)); //注意确定边界
  25. }
  26. if (key) {
  27. cout << "Merge Sort" << endl;
  28. cout << a[0];
  29. for (int j = 1; j < n; j++)
  30. cout << " " << a[j];
  31. return;
  32. }
  33. if (equal(a, a + n, b))
  34. key = 1;
  35. if (i > n)
  36. break;
  37. }
  38. }
  39. int main() {
  40. cin >> n;
  41. int a1[100], a2[100], b[100];
  42. for (int i = 0; i < n; i++) {
  43. cin >> a1[i];
  44. a2[i] = a1[i];
  45. }
  46. for (int i = 0; i < n; i++)
  47. cin >> b[i];
  48. insort(a2, b);
  49. mesort(a1, b);
  50. return 0;
  51. }

PAT 1035 插入与归并(25)(代码+思路+测试点分析)的更多相关文章

  1. PAT 1035. 插入与归并(25)

    根据维基百科的定义: 插入排序是迭代算法,逐一获得输入数据,逐步产生有序的输出序列.每步迭代中,算法从输入序列中取出一元素,将之插入有序序列中正确的位置.如此迭代直到全部元素有序. 归并排序进行如下迭 ...

  2. PAT (Basic Level) Practise (中文)-1035. 插入与归并(25)

    PAT (Basic Level) Practise (中文)-1035. 插入与归并(25)   http://www.patest.cn/contests/pat-b-practise/1035 ...

  3. PAT-乙级-1035. 插入与归并(25)

    1035. 插入与归并(25) 时间限制 200 ms 内存限制 65536 kB 代码长度限制 8000 B 判题程序 Standard 作者 CHEN, Yue 根据维基百科的定义: 插入排序是迭 ...

  4. PAT 1035 插入与归并(25)

    原题:https://pintia.cn/problem-sets/994805260223102976/problems/994805286714327040传送门: 根据维基百科的定义: 插入排序 ...

  5. PAT——1035. 插入与归并

    根据维基百科的定义: 插入排序是迭代算法,逐一获得输入数据,逐步产生有序的输出序列.每步迭代中,算法从输入序列中取出一元素,将之插入有序序列中正确的位置.如此迭代直到全部元素有序. 归并排序进行如下迭 ...

  6. PAT 1035 插入与归并

    https://pintia.cn/problem-sets/994805260223102976/problems/994805286714327040 据维基百科的定义: 插入排序是迭代算法,逐一 ...

  7. 1035 插入与归并 (25 分)C语言

    根据维基百科的定义: 插入排序是迭代算法,逐一获得输入数据,逐步产生有序的输出序列.每步迭代中,算法从输入序列中取出一元素,将之插入有序序列中正确的位置.如此迭代直到全部元素有序. 归并排序进行如下迭 ...

  8. PAT 1074 宇宙无敌加法器(20)(代码+思路+测试点分析)

    1074 宇宙无敌加法器(20 分)提问 地球人习惯使用十进制数,并且默认一个数字的每一位都是十进制的.而在 PAT 星人开挂的世界里,每个数字的每一位都是不同进制的,这种神奇的数字称为"P ...

  9. PAT 1028 人口普查(20)(STL-set+思路+测试点分析)

    1028 人口普查(20)(20 分) 某城镇进行人口普查,得到了全体居民的生日.现请你写个程序,找出镇上最年长和最年轻的人. 这里确保每个输入的日期都是合法的,但不一定是合理的--假设已知镇上没有超 ...

随机推荐

  1. border-radius bug 收集

    border-radius我相信对于老一辈的前端们有着特殊的感情,在经历了没有圆角的蛮荒时代,到如今 CSS3 遍地开花,我们还是很幸福的. 然而即使到了三星大脸流行时代,border-radius在 ...

  2. mysql监控以及调优

    mysql 优点: 简单易用,成本低,易扩展,复制功能领先 mysql的生命周期: Mysql服务器监听3306端口>验证访问用户>创建mysql线程>检查内存(Qcache)> ...

  3. nodejs——压缩文件_archiver

    工作需要,由于html无法访问并下载带有中文的路径,例子:“127.0.0.1::8088/files/第一张图片.jpg”,所以想到了先将原图片压缩并命名为不带中文的文件名,下载后用户自行解压缩的方 ...

  4. 隐藏bat脚本运行时弹出的黑窗口,以隐藏进程在后台执行.

    1.把这段代码写在前面@echo offif "%1"=="r" goto startif "%1"=="h" goto ...

  5. CUDA C Programming Guide 在线教程学习笔记 Part 2

    ▶ 纹理内存使用 ● 纹理内存使用有两套 API,称为 Object API 和 Reference API .纹理对象(texture object)在运行时被 Object API 创建,同时指定 ...

  6. Gson进行json字符串和对象之间的转化

    Gson可以实现对象与json字符串之间的转化,以下是在Android中的示例代码. Gson主页:https://code.google.com/p/google-gson/ public clas ...

  7. node 把前台传来的base64码转成图片存放

    最近做个人网站头像修改用到了,在做头像修改,先做了一个图片切割,只需要上传你选中部分, 如图 这种需求 应该还是会遇到的, http://pan.baidu.com/s/1boVkn1t 这是裁剪图片 ...

  8. 使用MATPLOTLIB 制图(散点图,热力图)

    import numpy as np import pandas as pd import matplotlib.pyplot as plt data = pd.read_csv('D:\\myfil ...

  9. Simple2D-22(重构)纹理池

    以前 Simple2D 使用 TextureManager,现在将它改为 TexturePool (纹理池).主要是负责加载和管理纹理,这次为 TexturePool 添加纹理集的功能,纹理集就是将大 ...

  10. 18 subprocess模块(跟操作系统交互)

    1.基本概念介绍 我们经常需要通过Python去执行一条系统命令或脚本,系统的shell命令是独立于你的python进程之外的, 每执行一条命令,就是发起一个新进程,通过python调用系统命令或脚本 ...