csu 1552: Friends 二分图 + Miller_Rabin
http://acm.csu.edu.cn/csuoj/problemset/problem?pid=1552
把那n个数写两次,分成相同的两堆,判断相加是质数的,连一条边,然后找最大匹配,ans = 最大匹配 / 2
做的时候一直超时,原来是Miller_Rabin的quick_pow那里需要quick_mul配合,不然溢出。
#include <stdio.h>
#include <stdlib.h>
#include <cstring>
#include <cmath>
#include <iostream>
#include <queue>
#include <vector>
#include <algorithm>
#include <map>
#include <time.h>
#define clr(u,v); memset(u,v,sizeof(u));
using namespace std;
typedef long long LL;
const int maxn = + ;
const int check_time = ;
bool e[maxn][maxn]; LL quick_mul(LL a, LL b, LL MOD) {
//求解 a*b%MOD的算法 // 原理:2*19 = 2*(1+2+16)
LL base = a % MOD;
b %= MOD; // a*b%MOD 等价于 (a%MOD * b%MOD) % MOD;
LL ans = ; //记住是0 因为中间过程是加
while (b) {
if (b & ) {
ans = (ans + base); //直接取模慢很多
if (ans >= MOD) ans -= MOD;
}
base = (base << ); //notice
if (base >= MOD) base -= MOD;
b >>= ;
}
return ans;
}
LL quick_pow(LL a, LL b, LL MOD) { //求解 a^b%MOD的值
LL base = a % MOD;
LL ans = ; //相乘,所以这里是1
while (b) {
if (b & ) {
ans = quick_mul(ans, base, MOD); //如果这里是很大的数据,就要用quick_mul
}
base = quick_mul(base, base, MOD); //notice。注意这里,每次的base是自己base倍
b >>= ;
}
return ans;
}
bool check(LL a, LL n, LL x, LL t) { //以a为基。n-1写成了 2^t * k,判断n是否为合数
LL ret = quick_pow (a, x, n); //先算 a^k%n 后来一直平方.平方t次
LL last = ret; //last就是a^k次方这个值,看成整体。符合X^2这个公式
for (int i = ; i <= t; ++i) {
ret = quick_mul(ret, ret, n); //平方他,last就是一个大X,ret是X^2
if (ret == && last != && last != n - ) return true; //合数
last = ret;
}
if (ret != ) return true; //费马小定理,如果a^(n-1)%n != 1就绝逼不是素数
return false;
}
bool Miller_Rabin(LL n) { //判断n是否质数
if (n < ) return false;
if (n == ) return true;
if (n % == ) return false; //偶数不是质数
LL k = n - ;
LL t = ; //把n-1拆成 2^t * k 这种形式,那么从k开始验证,a^k,不断平方即可
while ( (k & ) == ) { //如果x还是偶数的话,就是还有2的因子
k >>= ;
t++;
}
for (int i = ; i <= check_time; i++) {
LL a = rand() % (n - ) + ; //最大去到n-1,[1,n-1]
if (check (a, n, k, t)) //n-1写成了 2^t * k.米勒测试
return false; //合数
}
return true; //质数
} LL arr[maxn];
int n;
int match[maxn];
bool vis[maxn];
int dfs(int u) {
for (int i = ; i <= n; ++i) {
if (!vis[i] && e[u][i]) {
vis[i] = true;
if (match[i] == || dfs(match[i])) {
match[i] = u;
return ;
}
}
}
return ;
}
int hungary() {
memset(match, , sizeof match);
int ans = ;
for (int i = ; i <= n; ++i) {
memset(vis, false, sizeof vis);
if (dfs(i)) ans++;
}
return ans / ;
}
void work() {
memset(e, false, sizeof e);
// memset(match, 0, sizeof match);
for (int i = ; i <= n; ++i) {
scanf("%lld", &arr[i]);
}
for (int i = ; i <= n; ++i) {
for (int j = i + ; j <= n; ++j) {
if (Miller_Rabin(arr[i] + arr[j])) {
e[i][j] = true;
e[j][i] = true;
}
}
}
// for (int i = 1; i <= n; ++i) {
// for (int j = 1; j <= n; ++j) {
// cout << e[i][j] << " ";
// }
// cout << endl;
// }
printf("%d\n", hungary());
} int main() {
#ifdef local
freopen("case.in", "r", stdin);
// freopen("out.out", "w", stdout);
#endif
srand(time(NULL));
// cout << Miller_Rabin(1) << endl;
while (scanf("%d", &n) != EOF) work();
return ;
}
csu 1552: Friends 二分图 + Miller_Rabin的更多相关文章
- csu 1552(米勒拉宾素数测试+二分图匹配)
1552: Friends Time Limit: 3 Sec Memory Limit: 256 MBSubmit: 723 Solved: 198[Submit][Status][Web Bo ...
- CSU 1552 Friends(二分图 + 米勒测试)
题目链接:http://acm.csu.edu.cn/csuoj/problemset/problem?pid=1552 Description On an alien planet, every e ...
- CSU 1552: Friends 图论匹配+超级大素数判定
1552: Friends Time Limit: 3 Sec Memory Limit: 256 MBSubmit: 163 Solved: 34[Submit][Status][Web Boa ...
- HDU2389(KB10-F 二分图最大匹配Hopcroft_Karp)
Rain on your Parade Time Limit: 6000/3000 MS (Java/Others) Memory Limit: 655350/165535 K (Java/Ot ...
- BZOJ.4514.[SDOI2016]数字配对(费用流SPFA 二分图)
BZOJ 洛谷 \(Solution\) 很显然的建二分图后跑最大费用流,但有个问题是一个数是只能用一次的,这样二分图两部分都有这个数. 那么就用两倍的.如果\(i\)可以向\(j'\)连边,\(j\ ...
- CSU 1508:地图的四着色(DFS+剪枝)
http://acm.csu.edu.cn/OnlineJudge/problem.php?id=1508 题意:地图中四联通的块是一个国家,A和B每个人可以涂两种颜色,且B不能涂超过5次,相邻的国家 ...
- C - NP-Hard Problem(二分图判定-染色法)
C - NP-Hard Problem Crawling in process... Crawling failed Time Limit:2000MS Memory Limit:262144 ...
- POJ 2125 Destroying the Graph 二分图最小点权覆盖
Destroying The Graph Time Limit: 2000MS Memory Limit: 65536K Total Submissions: 8198 Accepted: 2 ...
- bzoj4025 二分图
支持加边和删边的二分图判定,分治并查集水之(表示我的LCT还很不熟--仅仅停留在极其简单的模板水平). 由于是带权并查集,并且不能路径压缩,所以对权值(到父亲距离的奇偶性)的维护要注意一下. 有一个小 ...
随机推荐
- hibernate入门(-)
1.struts2的支持 在web.xml中配置struts2的支持 <?xml version="1.0" encoding="UTF-8"?> ...
- RequireJS 加载 js 执行顺序
初次接触RequireJS 对文档理解不很透彻,自己通过测试测到的执行顺序: 文档结构: |-amaze | -js | -amazeui.js | -jquery.min.js | -main.js ...
- 「USACO13MAR」「LuoguP3080」 牛跑The Cow Run (区间dp
题目描述 Farmer John has forgotten to repair a hole in the fence on his farm, and his N cows (1 <= N ...
- js 改变对象的引用地址
在业务处理中我们经常会碰到列表中有编辑和新增按钮,为了能够提高代码的公用性,我们经常会使用同一组件处理. 这样会出现一个问题就是编辑的时候直接把对象传过去,直接赋值,引用地址是同一个,所以不管修改了那 ...
- vim vi Ubuntu 设置
1. 在vi编辑模式下按退格键不能删除内容,按方向键不能上下左右移动?如果是则:一 在vi里非编辑模式下按冒号进入到末行命令模式,然后输入set nocompatible,回车,然后在进入vi编辑模式 ...
- 二、Chrome开发者工具详解(2)-Network面板
摘自: http://www.cnblogs.com/charliechu/p/5981346.html
- cocos2d-x2.2+win7+vs2010+python安装配置
个人网站http://www.ravedonut.com/ 1.安装vs2010 2.解压cocos2d-x,打开cocos2d-win32.vc2012.sln,编译,然后运行Hellocpp成功即 ...
- JAVA实现DIJKSTRA算法
import java.util.Queue; import java.util.LinkedList; public class dijkstra{ public static void main( ...
- 支持lua的框架和ide
1.Kony http://mobilehub.io/products/kony 2.CryEngine http://mobilehub.io/products/cryengine 3.Dragon ...
- 程序兵法:Java String 源码的排序算法(一)
摘要: 原创出处 https://www.bysocket.com 「公众号:泥瓦匠BYSocket 」欢迎关注和转载,保留摘要,谢谢! 这是泥瓦匠的第103篇原创 <程序兵法:Java Str ...