1089 Insert or Merge
According to Wikipedia:
Insertion sort iterates, consuming one input element each repetition, and growing a sorted output list. Each iteration, insertion sort removes one element from the input data, finds the location it belongs within the sorted list, and inserts it there. It repeats until no input elements remain.
Merge sort works as follows: Divide the unsorted list into N sublists, each containing 1 element (a list of 1 element is considered sorted). Then repeatedly merge two adjacent sublists to produce new sorted sublists until there is only 1 sublist remaining.
Now given the initial sequence of integers, together with a sequence which is a result of several iterations of some sorting method, can you tell which sorting method we are using?
Input Specification:
Each input file contains one test case. For each case, the first line gives a positive integer N (≤). Then in the next line, N integers are given as the initial sequence. The last line contains the partially sorted sequence of the N numbers. It is assumed that the target sequence is always ascending. All the numbers in a line are separated by a space.
Output Specification:
For each test case, print in the first line either "Insertion Sort" or "Merge Sort" to indicate the method used to obtain the partial result. Then run this method for one more iteration and output in the second line the resuling sequence. It is guaranteed that the answer is unique for each test case. All the numbers in a line must be separated by a space, and there must be no extra space at the end of the line.
Sample Input 1:
10
3 1 2 8 7 5 9 4 6 0
1 2 3 7 8 5 9 4 6 0
Sample Output 1:
Insertion Sort
1 2 3 5 7 8 9 4 6 0
Sample Input 2:
10
3 1 2 8 7 5 9 4 0 6
1 3 2 8 5 7 4 9 0 6
Sample Output 2:
Merge Sort
1 2 3 8 4 5 7 9 0 6
题意:
给出一个序列的初始状态以及排序过程中的一种状态,判断属于那种排序方式。
思路:
刚开始是根据mooc上面老师讲的思路来做的,先判断是不是插入排序,若不是插入排序,则是归并排序。归并排序本来是想的找出当前归并段的长度(len),下次排序直接将相邻的两个len归并成一个。但是提交的时候发现有测试点过不去。于是就选择了模拟的办法,sort两个归并段。
Code:
#include<iostream>
#include<vector>
#include<algorithm> using namespace std; void Merge(vector<int> &p, vector<int> &t, int l, int r, int Rend) {
int Lend = r - 1;
int prt = l;
while (l <= Lend && r <= Rend) {
if (p[l] < p[r]) t[prt++] = p[l++];
if (p[r] < p[l]) t[prt++] = p[r++];
}
while (l <= Lend) t[prt++] = p[l++];
while (r <= Rend) t[prt++] = p[r++];
int len = 2 * (Rend - Lend);
for (int i = 0; i < len; ++i, Rend--) p[Rend] = t[Rend];
} int main() {
int n;
cin >> n; vector<int> init(n);
vector<int> part(n);
vector<int> temp(n); int t, p, q;
for (int i = 0; i < n; ++i) {
cin >> t;
init[i] = t;
}
for (int i = 0; i < n; ++i) {
cin >> t;
part[i] = t;
}
p = 1;
while (p < n && part[p] > part[p-1]) ++p;
p++;
q = p;
while (q < n && part[q] == init[q]) ++q; if (q == n) {
cout << "Insertion Sort" << endl;
sort(part.begin(), part.begin()+p);
cout << part[0];
for (int i = 1; i < n; ++i) cout << " " << part[i];
} else {
cout << "Merge Sort" << endl;
int j, k;
bool flag = false;
for (j = 1; j < n; j *= 2) {
k = j - 1;
while (k + 1 < n) {
if (part[k] < part[k+1]) k += 2 * j;
else { flag = true; break; }
}
if (flag) break;
}
for (k = 0; k <= n-2*j; k += 2*j) {
Merge(part, temp, k, k+j, k+2*j-1);
}
if (k + j < n)
Merge(part, temp, k, k+j, n); cout << part[0];
for (int i = 1; i < n; ++i) cout << " " << part[i];
} cout << endl; return 0;
}
骗了15分。
#include<iostream>
#include<vector>
#include<algorithm> using namespace std; int main() {
int n;
cin >> n; vector<int> init(n);
vector<int> part(n);
vector<int> temp(n); int t, p, q;
for (int i = 0; i < n; ++i) {
cin >> t;
init[i] = t;
}
for (int i = 0; i < n; ++i) {
cin >> t;
part[i] = t;
}
for (p = 0; p < n-1 && part[p] <= part[p+1]; p++);
for (q = p+1; init[q] == part[q] && q < n; q++);
if (q == n) {
cout << "Insertion Sort" << endl;
sort(part.begin(), part.begin()+p+2);
cout << part[0];
for (int i = 1; i < n; ++i) cout << " " << part[i];
} else {
cout << "Merge Sort" << endl;
int j, k = 1;
bool flag = true;
while (flag) {
flag = false;
for (int i = 0; i < n; ++i) {
if (init[i] != part[i])
flag = true;
}
k *= 2;
for (j = 0; j < n/k; ++j)
sort(init.begin()+j*k, init.begin()+(j+1)*k);
sort(init.begin()+(n/k)*k, init.end());
}
cout << init[0];
for (int i = 1; i < n; ++i)
cout << " " << init[i];
} cout << endl; return 0;
}
参考:
https://www.liuchuo.net/archives/1902
1089 Insert or Merge的更多相关文章
- PAT甲级1089. Insert or Merge
PAT甲级1089. Insert or Merge 题意: 根据维基百科: 插入排序迭代,消耗一个输入元素每次重复,并增加排序的输出列表.每次迭代,插入排序从输入数据中删除一个元素,在排序列表中找到 ...
- PAT 1089 Insert or Merge[难]
1089 Insert or Merge (25 分) According to Wikipedia: Insertion sort iterates, consuming one input ele ...
- PAT甲级:1089 Insert or Merge (25分)
PAT甲级:1089 Insert or Merge (25分) 题干 According to Wikipedia: Insertion sort iterates, consuming one i ...
- 1089 Insert or Merge(25 分)
According to Wikipedia: Insertion sort iterates, consuming one input element each repetition, and gr ...
- PAT 1089. Insert or Merge (25)
According to Wikipedia: Insertion sort iterates, consuming one input element each repetition, and gr ...
- 1089. Insert or Merge (25)
题目如下: According to Wikipedia: Insertion sort iterates, consuming one input element each repetition, ...
- 1089. Insert or Merge (25)-判断插入排序还是归并排序
判断插入排序很好判断,不是的话那就是归并排序了. 由于归并排序区间是2.4.8开始递增的,所以要判断给出的归并排序执行到哪一步,就要k从2开始枚举. 然后再对每个子区间进行一下sort即可. #inc ...
- PAT (Advanced Level) 1089. Insert or Merge (25)
简单题.模拟一下即可. #include<cstdio> #include<cstring> #include<cmath> #include<vector& ...
- PAT 1089. Insert or Merge
Insertion sort iterates, consuming one input element each repetition, and growing a sorted output li ...
- 1089 Insert or Merge (25 分)
According to Wikipedia: Insertion sort iterates, consuming one input element each repetition, and gr ...
随机推荐
- Java常用类:Scanner类
一.简介 java.util.Scanner是Java5的新特征,我们可以通过Scanner类来获取用户的输入. 二.创建对象 示例: Scanner scanner = new Scanner(Sy ...
- 【HTB系列】靶机Teacher的渗透测试详解
出品|MS08067实验室(www.ms08067.com) 本文作者:大方子(Ms08067实验室核心成员) Kali: 10.10.14.50 靶机地址:10.10.10.153 先用nmap 对 ...
- Python 过滤字母和数字
[前言]在写爬虫时,正则表达式有时候比较难写,一个是自己不熟练,二者数据分析提取数据千奇百怪. 一.好在python有个re模块,提供了很多更加简便的方法:可参考此文档:https://www.cnb ...
- 使用Prometheus搞定微服务监控
最近对服务进行监控,而当前监控最流行的数据库就是 Prometheus,同时 go-zero 默认接入也是这款数据库.今天就对 go-zero 是如何接入 Prometheus ,以及开发者如何自己定 ...
- AntDesign Pro + .NET Core 实现基于JWT的登录认证
很多同学说AgileConfig的UI实在是太丑了.我想想也是的,本来这个项目是我自己使用的,一开始甚至连UI都没有,全靠手动在数据库里修改数据.后来加上了UI也是使用了老掉牙的bootstrap3做 ...
- 六. SpringCloud网关
1. Gateway概述 1.1 Gateway是什么 服务网关还可以用Zuul网关,但是Zuul网关由于一些维护问题,所以这里我们学习Gateway网关,SpringCloud全家桶里有个很重要的组 ...
- POJ-3259(最短路+Bellman-Ford算法判负圈)
Wormholes POJ-3259 这题是最短路问题中判断是否存在负圈的模板题. 判断负圈的一个关键就是理解:如果在图中不存在从s可达的负圈,最短路径不会经过一个顶点两次.while循环最多执行v- ...
- Flink的日志配置
------------恢复内容开始------------ 介绍flink在本地运行和on yarn运行时的日志配置. 很多现代框架都是用门面模式进行日志输出,例如使用Slf4j中的接口输出日志,具 ...
- 动态规划-最长公共上升子序列-n^2解法
1. 题目描述 给定两个数列\(A, B\),如果他们都包含一段位置不一定连续的数,且数值是严格递增的,那么称这一段数是两个数列的公共上升子序列.求\(A\)和\(B\)的最长公共上升子序列. 输入格 ...
- slickgrid ( nsunleo-slickgrid ) 4 解决点击不切换单元格的问题
slickgrid ( nsunleo-slickgrid ) 4 解决点击不切换单元格的问题 上一次解决了列选择和区域选择冲突的问题,昨天太忙了,并且要陪小宝早点睡觉,就啥也没有赶上.今天上班面试. ...