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还很不熟--仅仅停留在极其简单的模板水平). 由于是带权并查集,并且不能路径压缩,所以对权值(到父亲距离的奇偶性)的维护要注意一下. 有一个小 ...
随机推荐
- html5--4-1 video/视频播放
html5--4-1 video/视频播放 学习要点 掌握video元素的基本用法 直到现在,在网页中的大多数视频是通过插件(比如 Flash)来显示的.然而,并非所有浏览器都拥有同样的插件. HTM ...
- noip2005篝火晚会
这是一道不算太难的题,但愚蠢的我并没有想到. 首先,判断无解的情况:他想相邻的不想与他相邻. 然后,构造出合法的数列,因为第一位左边有两种选择,且构造出的环不等价,所以要做两次. (这一点我并没有想清 ...
- SSL peer shut down incorrectly
这个问题通常出现在Android Studio更新失败的时候, 原因是download http://services.gradle.org/distributions/gradle-2.2-all. ...
- XML与TreeView
1.treeview代码书写 private void Form1_Load(object sender, EventArgs e) { //代码为TreeView添加子项 treeView1.Con ...
- js 异步问题
如果发现前端的异步请求,network有发送成功而且有返回值,但是没有进前端的callback成功回掉函数内,这时候就需要检查是不是配置文件做了语法限制,只能返回某些数据格式,不能返回某些数据格式. ...
- 关于yolov3 训练输出值
Region xx: cfg文件中yolo-layer的索引: Avg IOU:当前迭代中,预测的box与标注的box的平均交并比,越大越好,期望数值为1: Class: 标注物体的分类准确率,越大越 ...
- node.js版本管理(Win) --- nvm-window
目录 1. 安装 2. 使用 1. 安装 去往Git链接:https://github.com/coreybutler/nvm-windows. 点击下载链接: 选择第一个nvm-noinstall. ...
- hibernate的优缺点和适用场合
Hibernate优点: 1.对象化.人员以面相对象的思想来操作数据库.Hibernate支持许多面向对象的特性,如组合,继承,多态等. 2.更好的移植性.对于不同的数据库,开发者只需要使用相同的数据 ...
- SpringMVC注解说明
@controller 通过@controller标注即可将class定义为一个controller类. @RequestMapping value 表示需要匹配的url的格式. method 表示所 ...
- Lecture 0 --基本说明
Abstract:本章所记录的知识是后面章节需要的前导知识,请务必仔细读本章,理解涉及的知识点,方便后面章节的学习.本次数据结构笔记主要参考殷人昆的<数据结构(C语言描述)>这本书,需要的 ...