DTOJ 4774. A

题意

你有一个大小为 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,T3×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,用队双端列维护即可。

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值