NOIP2018 全国热身赛 第二场 (不开放)

NOIP2018 全国热身赛 第二场 (不开放)

题目链接:http://noi.ac/contest/26/problem/60
一道蛮有趣的题目.
然后比赛傻逼了.
即将做出来的时候去做别的题了.
100分没了
可以想到的是.
2操作时,是将每个球的位置 (-1) ,然后把最左边的球放到 (P-1) 处。
之后记录一个(-1) 次数保证相对位置不变.
然后用set维护一下.(map + queue也可以)

#include <iostream>
#include <set>
#include <cstdio>
#define rep(i,x,p) for(int i = x;i <= p;++ i)
#define sep(i,x,p) for(int i = x;i >= p;-- i)
#define gc getchar()
using namespace std;

set <int>s;

inline int read() {
	int x = 0,f = 1;char c = gc;
	while(c < '0' || c > '9') {if(c == '-')f = -1;c = gc;}
	while(c >= '0' && c <= '9') {x = x * 10 + c - '0';c = gc;}
	return x * f;
}

int main() {
	int n,m,P,x,tot = 0;
	n = read();m = read();P = read();
	rep(i,1,n) {x = read();s.insert(x);}
	while(m --) {
		int type = read();
		if(type == 1) {
			x = read();
			s.insert(x + tot);
		}else {
			tot ++;
			s.erase(s.begin());
			s.insert(P + tot - 1);
		}
	}
	for (set<int>::iterator i=s.begin();i!=s.end();i++) cout<<*i-tot<<' ';cout<<endl;
	return 0;
}

原文地址:https://www.cnblogs.com/tpgzy/p/9825136.html