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还很不熟--仅仅停留在极其简单的模板水平). 由于是带权并查集,并且不能路径压缩,所以对权值(到父亲距离的奇偶性)的维护要注意一下. 有一个小 ...
随机推荐
- codeforces B. Coach 解题报告
题目链接:http://codeforces.com/problemset/problem/300/B 题目意思:给出n个students(n%3 = 0),编号依次为1-n,接下来有m行,每行有两个 ...
- html5--5-3 给直线添加样式
html5--5-3 给直线添加样式 学习要点 strokeStyle属性:设置颜色.渐变或模式(本节课只涉及到颜色) lineWidth属性:--设置线宽 Canvas的路径方法 moveTo() ...
- TCP/IP 协议 —— ARP
通过 ARP 广播获得对方的 MAC 地址: 地址解析协议,即ARP(Address Resolution Protocol),是根据IP地址获取物理地址的一个TCP/IP协议. 1. 特点 ARP ...
- WinDbg 调试工具的使用
概述 项目接近尾声了,可是在运行时会有memory leak(内存泄露) bug.产品在运行一天后,内存增长致1.4G,而我们产品的初始内存才有70M,问题很严重,决定采用WinDbg工具来分析代码问 ...
- 【linux+C】神器 vim + 指针相关客串
前篇回顾 上篇介绍了linux下C编程基本环境配置以及相关工具使用选择. 不过10个大牛9个用vim,那么咱们就来玩vim.linux下玩c就别依靠图形界面.好吧告别Ide,命令行才是c的王道. 本篇 ...
- MVC中为自动生成实体类添加验证
将额外的基于特性的元数据(象验证特性)施加到由VS设计器自动生成/维护的类的一个方法是,采用一个我们称之为“伙伴类(buddy classes)”的技术. 基本上来说,你创建另外一个类,包含你的验证特 ...
- PLSQL ORA-12154 TNS无法解析指定的连接标识符
若你的机子上Windows 64位操作系统, 将PL Sql 的默认安装目录 Program Files (x86) 文件夹改为Program Files 或者别的便可以了
- 4-1eclipse & 4-2在eclipse下开发Java
ecplise是一款继承的开发工具,可以开发我们的java程序. 下载地址: https://www.eclipse.org/downloads/ 视频中ecplise的版本 安装Ecplise: 默 ...
- HDU - 4006 The kth great number multiset应用(找第k大值)
The kth great number Xiao Ming and Xiao Bao are playing a simple Numbers game. In a round Xiao Ming ...
- LeetCode: 496 Next Greater Element I(easy)
题目: You are given two arrays (without duplicates) nums1 and nums2 where nums1’s elements are subset ...