[BZOJ 4857][Jsoi2016]反质数序列
$ \color{green} {solution : } $
因为 $ 1 $ 的个数我们最多只能选一个,所以剩下的数如果组成素数那么只有一奇一偶,显然是个二分图模型
#include <bits/stdc++.h>
using namespace std;
const int maxn = 1000010, inf = 0x3f3f3f3f;
int head[maxn], to[maxn << 1], v[maxn << 1], pos[maxn << 1], p;
inline void build(int a, int b, int c) {
v[++ p] = b; to[p] = head[a]; head[a] = p; pos[p] = c;
}
int dis[maxn], cur[maxn], s, t;
queue<int> tp;
bool bfs() {
memset(dis, 0, sizeof(dis)); dis[s] = 1; tp.push(s);
while ( !tp.empty()) {
int u = tp.front(); tp.pop();
for ( int i = head[u]; ~i; i = to[i])
if( !dis[v[i]] && pos[i])
dis[v[i]] = dis[u] + 1, tp.push(v[i]);
}
for ( int i = s; i <= t; ++ i) cur[i] = head[i];
return dis[t] != 0;
}
int dfs(int u, int f) {
if( !f || u == t) return f;
int flow = 0;
for ( int &i = cur[u]; ~i; i = to[i])
if( dis[v[i]] == dis[u] + 1){
int k = dfs(v[i], min(f, pos[i]));
if( k) {
pos[i] -= k; pos[i ^ 1] += k;
flow += k; f -= k;
if( !f) return flow;
}
}
return flow;
}
int max_flow() {
int ret = 0;
while ( bfs()) ret += dfs(s, inf);
return ret;
}
int prim[maxn], book[maxn], vl[maxn], cnt[maxn], tot, n;
int main() {
#ifndef ONLINE_JUDGE
freopen("2.in", "r", stdin);
#endif
memset(head, -1, sizeof(head)); p = -1;
scanf("%d", &n);
for ( int i = 1; i <= n; ++ i) scanf("%d", vl + i);
sort(vl + 1, vl + 1 + n);
int op = 1;
for ( int i = 1; i <= n; ++ i) {
if( vl[i] != vl[op]) vl[++ op] = vl[i];
++ cnt[op];
}
n = op; if( vl[1] == 1) cnt[1] = 1;
s = 0; t = n + 1;
for ( int i = 2; i <= (vl[n] << 1); ++ i) {
if( !book[i]) prim[++ tot] = i;
for ( int k = 1; k <= tot; ++ k) {
if( i * prim[k] > (vl[n] << 1)) break;
book[i * prim[k]] = 1;
if( i % prim[k] == 0) break;
}
}
int ret = 0;
for ( int i = 1; i <= n; ++ i) {
ret += cnt[i];
if( vl[i]&1) {
build(s, i, cnt[i]), build(i, s, 0);
for ( int k = 1; k <= n; ++ k) if( !book[vl[i]+vl[k]])
build(i, k, inf), build(k, i, 0);
}
else build(i, t, cnt[i]), build(t, i, 0);
}
printf("%d\n", ret - max_flow());
return 0;
}
[BZOJ 4857][Jsoi2016]反质数序列的更多相关文章
- [BZOJ4857][JSOI2016]反质数序列[最大点独立集]
题意 在长度为 \(n\) 的序列 \(a\) 中选择尽量长的子序列,使得选出子序列中任意两个数的和不为质数. \(n\leq3000\ ,a_i\leq10^5\). 分析 直接按照奇偶性建立二分图 ...
- [JSOI2016]反质数序列
我竟然半个小时切了一道JSOI2016,,,,不敢相信. 首先可以发现,如果N个数中1出现的次数<=1的话,我们按不能在一个集合连无向边的话,连出的一定是一个二分图. 接下来我来证明一下: 因为 ...
- BZOJ 4857 反质数序列
题面 奇数+奇数一定不是质数(1+1除外),偶数+偶数一定不是质数,质数只可能出现在偶数+奇数中 把所有的点排成两列,权值为奇数的点在左边,权值为偶数的在右边 如果左边的点x+右边的点y是质数,我们就 ...
- 【LOJ】#2081. 「JSOI2016」反质数序列
题解 我居然都没反应过来二分图内选集合两两不能有边是最大独立集了 我退役吧 显然连边只能在奇数和偶数之间,然后二分图求最大独立集是节点数-最大匹配数 啊当然还有对于1的话只能留一个1 代码 #incl ...
- bzoj:3085: 反质数加强版SAPGAP
Description 先解释一下SAPGAP=Super AntiPrime, Greatest AntiPrime(真不是网络流),于是你就应该知道本题是一个关于反质数(Antiprime)的问题 ...
- BZOJ 4753 [Jsoi2016]最佳团体 | 树上背包 分数规划
BZOJ 4753 [Jsoi2016]最佳团体 | 树上背包 分数规划 又是一道卡精度卡得我头皮发麻的题-- 题面(--蜜汁改编版) YL大哥是24OI的大哥,有一天,他想要从\(N\)个候选人中选 ...
- BZOJ1053 [HAOI2007]反素数 & BZOJ3085 反质数加强版SAPGAP
BZOJ 1053 Description 对于任何正整数x,其约数的个数记作g(x).例如g(1)=1.g(6)=4.如果某个正整数x满足:g(x)>g(i) 0<i<x ,则称x ...
- CNUOJ 0486 800401反质数
难度级别:A: 运行时间限制:1000ms: 运行空间限制:51200KB: 代码长度限制:2000000B 试题描述 将正整数 x 的约数个数表示为 g(x).例如,g(1)=1,g(4)=3, g ...
- 反质数问题,求不大于n的最大反质数
反质数:设f(n)表示n个约数的个数,如果对于任意x有0<x<n, f(x) < f(n),那么n就是一个反质数 我们都知道对于任意一个数n,都可以用质数乘积的形式表示出来:x = ...
随机推荐
- unary_function和binary_function详解
1.unary_function和binary_function介绍 1.1 unary_function介绍 unary_function可以作为一个一元函数对象的基类,它只定义了参数和返回值的类型 ...
- [c++] polymorphism without virtual function
polymorphism without virtual function
- [Training Video - 4] [Groovy] Initializing log inside class with constructor
TestService s = new TestService(log,context,testRunner) s.xyz() class TestService{ def log def conte ...
- 为什么丑陋的UI界面却能创造良好的用户体验?
本文内容由Mockplus团队翻译. 官网:http://www.mockplus.cn 网站界面过于漂亮可能会影响网站的可用性,但本文中提到的5个网站界面可谓是“丑”出了新高度.这样的网站它还有可用 ...
- Java设计模式(2)——工厂方法模式
工厂方法模式同样属于类的创建型模式又被称为多态工厂模式.工厂方法模式的意义是定义一个创建产品对象的工厂接口,将实际创建工作推迟到子类当中.核心工厂类不再负责产品的创建,这样核心类成为一个抽象工厂角色, ...
- spark读写Sequoiadb
spark如何读写Sequoiadb,最近被客户问多了,这个记录下. Spark读Sequoiadb数据: package marketing import com.sequoiadb.hadoop. ...
- java调.NET webapi时间戳报错问题
JAVA时间戳长度是13位,如:1294890876859 PHP .NET时间戳长度是10位, 如:1294890859 主要最后三位的不同,JAVA时间戳在.NETPHP中使用,去掉后三位,如:1 ...
- monkeyrunner小结
上次说到已经配好了MonkeyRunner的运行环境,现在讲解怎么进行简单的MonkeyRunner测试.这个拖了很久才有时间和心情总结一下.真是计划赶不上变化啊. 就不说废话了.http://dev ...
- redis整理の安全认证
设置客户端连接后进行任何其他指定前需要使用的密码. tips:因为 redis 速度相当快,所以在一台比较好的服务器下,一个外部的用户可以在一秒钟进 行 150K 次的密码尝试,这意味着你需要指定非常 ...
- memcached整理の内存管理及删除机制
内存的碎片化 如果用C语言直接malloc,free来向操作系统申请和释放内存时,在不断申请和释放的过程中,形成了一些很小的内存片段,无法再利用.这种空闲但无法利用内存的现象称为内存的碎片化. sla ...