AtCoder Regular Contest 080 F - Prime Flip 线性筛+匈牙利算法

题意

有一个无限长的01序列,其中n个位置上是1,其余都是0。每次可以选择一个长度为奇素数的区间,然后将这个区间内的元素取反。问最少多少步后可以将整个序列变为0。
n<=100,ai<=10^7

分析

首先差分一下,不难发现1的个数一定是偶数,那么操作就变成了每次可以把两个位置[l-1,r]同时取反。
现在问题就变成了让这偶数个1两两配对,使得总操作数最小。
对于两个数x和y
若|x-y|是奇素数,则需要一步操作。
若|x-y|是偶数,根据哥德巴赫猜想可知需要两步操作。
若|x-y|是奇合数,则可以先减掉一个3,然后就变成了偶数的情况,总共需要三步。
贪心地想肯定是步数越少的配对越多越好。
可以把位置按照下标奇偶性建二分图,然后跑匈牙利,最后不行的话再强行补后两种情况即可。

代码

#include<iostream>
#include<cstdio>
#include<cstdlib>
#include<cstring>
#include<algorithm>
using 
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值