C. Report
Posted planche
tags:
篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了C. Report相关的知识,希望对你有一定的参考价值。
题意:给出n个无序的数以及m个操作,每个操作由两个数组成,第一个数是操作的方式,第二个数 i 是操作的范围,若第一个数是1,则给 1-i 个数按升序排序,若第二个数是2,则给 1-i 个数按降序排列。输出所有操作完成后的序列。
int n, m; arr a, ans; int top = 0; int tot = 0; struct node { int r, tp, id; } p[N], q[N]; bool cmp(node a, node b) { if (a.r == b.r) return a.id > b.id; return a.r > b.r; } int main() { // file("test"); sdf(n), sdf(m); For(i, 1, n) sdf(a[i]); For(i, 1, m) { int x, y; sdf(x), sdf(y); p[i] = (node){y, x, i}; } sort(p + 1, p + 1 + m, cmp); int st = 1; For(i, 1, m) { if (p[i].id < st) continue; st = p[i].id; if (i >= 2 && p[i].tp == q[tot].tp) continue; q[++tot] = p[i]; if (p[i].id == m) break; } top = n+1; FFor(i, n, q[1].r + 1) ans[--top] = a[i]; sort(a + 1, a + 1 + q[1].r); int L = 1, R = q[1].r; For(i, 1, tot) { int dt = q[i].r - q[i + 1].r; if (q[i].tp == 1) { FFor(j, R, R-dt+1) ans[--top] = a[j]; R -= dt; } else { For(j, L, L + dt - 1) ans[--top] = a[j]; L += dt; } } For(i,1,n) printf("%d ", ans[i]); return 0; }
以上是关于C. Report的主要内容,如果未能解决你的问题,请参考以下文章
Codeforces Round #344 (Div. 2) 631 C. Report (单调栈)
Codeforces Round #344 (Div. 2) C. Report 水题
Codeforces Round #344 (Div. 2)C. Report
mvn命令异常:An error has occurred in Javadoc report generation: Unable to find javadoc command异常已解决(代码片段
mvn命令异常:An error has occurred in Javadoc report generation: Unable to find javadoc command异常已解决(代码片段
[Codeforces Round #522 (Div. 2, based on Technocup 2019 Elimination Round 3)][C. Playing Piano](代码片段