题意
你有一个大小为 n n n 的 0 / 1 0/1 0/1 序列。每一轮对于满足 a i = 0 a_i=0 ai=0 且 a i + 1 = 1 a_{i+1}=1 ai+1=1 的 i i i ,执行 swap(a[i],a[i+1]) 。
请输出操作 T T T 轮后的序列。
对于所有数据,保证 n , T ≤ 3 × 1 0 6 n,T \le 3 \times 10^6 n,T≤3×106
特殊性质一:没有两个1相邻
特殊性质二:1的个数不超过5000
测试点编号 | n = n= n= | 是否满足特殊性质一 | 是否满足特殊性质二 |
---|---|---|---|
1 | 1000 1000 1000 | ||
2 | 3000 3000 3000 | ||
3 | 5000 5000 5000 | ||
4 | 30000 30000 30000 | ||
5 | 50000 50000 50000 | ||
6 | 80000 80000 80000 | ||
7 | 1 0 5 10^5 105 | ||
8 | 1 0 5 10^5 105 | ||
9 | 1 0 5 10^5 105 | ||
10 | 3 × 1 0 5 3 \times 10^5 3×105 | 是 | |
11 | 3 × 1 0 5 3 \times 10^5 3×105 | 是 | |
12 | 3 × 1 0 5 3 \times 10^5 3×105 | 是 | |
13 | 3 × 1 0 5 3 \times 10^5 3×105 | 是 | |
14 | 3 × 1 0 5 3 \times 10^5 3×105 | 是 | |
15 | 3 × 1 0 5 3 \times 10^5 3×105 | ||
16 | 5 × 1 0 5 5 \times 10^5 5×105 | ||
17 | 3 × 1 0 6 3 \times 10^6 3×106 | ||
18 | 3 × 1 0 6 3 \times 10^6 3×106 | ||
19 | 3 × 1 0 6 3 \times 10^6 3×106 | ||
20 | 3 × 1 0 6 3 \times 10^6 3×106 |
题解
考虑从后往前依次确定每个0最后到达的位置:原本想的是记上一个0最后移动的时间,由此确定当前0的位置,但这样当前0最后移动的时间无法计算。
既然如此,那肯定要记下上一个0每个时间是否移动了(原本不敢往这想下去觉得不可做,有时候其实是被自己打败了啊),设每个时间移动为1,不移动为0。考虑转移,设当前0与上一个0距离为x,那么前x个时间都是1,后面的相当于可以把原有的前面的1往后推,即先右移一位,然后与前x个时间有重复的1再往后移到第一个0。直接维护1不好维护(每次会增加x个),考虑维护0,则每次只会增加时间1的0(如果时间t+1有0就删掉),然后从前往后弹掉x个0,用队双端列维护即可。