真·会了网络流,忘了匈牙利

一共两种颜色,很容易想到二分图劈配

虽然这题数据水

但是,数据强的话肯定会卡掉的。

为什么? 我暴力质因数都过了

我们可以在两边的数与质因数相连。然后跑网络流。

#include<algorithm>
#include<iostream>
#include<cstring>
#include<queue>
using namespace std;
struct node
{
int point;
int value;
int nxt;
};
node line[500000];
int head[500000],tail=-1;
void add(int x,int y,int dis,int base)
{
line[++tail].point=y;
if(base)
line[tail].value=dis;
line[tail].nxt=head[x];
head[x]=tail;
return ;
}
int read()
{
int s=0;
char in=getchar();
while(in<'0'||in>'9')
in=getchar();
while(in>='0'&&in<='9')
{
s=(s<<1)+(s<<3)+in-'0';
in=getchar();
}
return s;
}
int blue[500000],red[500000];
int pos[500000];
int cur[500000];
queue<int>q;
int dep[500000];
int tot;
bool bfs(int begin,int end)
{
for(int i=0;i<=tot;i++)
cur[i]=head[i];
while(!q.empty())
q.pop();
memset(dep,0,sizeof(dep));
dep[begin]=1;
q.push(begin);
while(!q.empty())
{
int pas=q.front();q.pop();
for(int i=head[pas];i!=-1;i=line[i].nxt)
if(!dep[line[i].point]&&line[i].value)
{
dep[line[i].point]=dep[pas]+1;
q.push(line[i].point);
}
}
if(dep[end])
return true;
return false;
}
int dfs(int now,int aim,int limte)
{
if(now==aim||!limte)
return limte;
int flow=0,f;
for(int i=cur[now];i!=-1;i=line[i].nxt)
{
cur[now]=i;
if(dep[line[i].point]==dep[now]+1&&(f=dfs(line[i].point,aim,min(limte,line[i].value))))
{
limte-=f;
flow+=f;
line[i].value-=f;
line[i^1].value+=f;
if(!limte)
break;
}
}
return flow;
}
int dinic(int begin,int end)
{
int res=0;
while(bfs(begin,end))
res+=dfs(begin,end,0x7fffffff);
return res;
}
bool not_prime[1100000];
int prime[100000],_tail;
void work()
{
not_prime[0]=not_prime[1]=true;
for(int i=2;i<=1000000;i++)
{
if(!not_prime[i])
prime[++_tail]=i;
for(int j=1;j<=_tail;j++)
{
if(prime[j]*i>=1000000)
break;
not_prime[prime[j]*i]=true;
if(prime[j]%i==0)
break;
}
}
return ;
}
int main()
{
int t=read();
work();
while(t--)
{
tot=0;
memset(head,-1,sizeof(head));
memset(pos,0,sizeof(head));
int m=read(),n=read();
tot=m+n+1;
int now=1;
for(int i=1;i<=m;i++)
{
blue[i]=read();
add(0,now,1,1);
add(now,0,1,0);
now+=1;
}
for(int i=1;i<=n;i++)
{
red[i]=read();
add(now,tot,1,1);
add(tot,now,1,0);
now+=1;
}
now=1;
for(int i=1;i<=m;i++)
{
for(int j=1;blue[i]!=1;j++)
{
if(!(blue[i]%prime[j]))
{
if(!pos[prime[j]])
pos[prime[j]]=++tot;
add(now,pos[prime[j]],1,1);
add(pos[prime[j]],now,1,0);
while(!(blue[i]%prime[j]))
blue[i]/=prime[j];
}
}
now+=1;
}
for(int i=1;i<=n;i++)
{
for(int j=1;red[i]!=1;j++)
{
if(!(red[i]%prime[j]))
{
if(!pos[prime[j]])
pos[prime[j]]=++tot;
add(pos[prime[j]],now,1,1);
add(now,pos[prime[j]],1,0);
while(!(red[i]%prime[j]))
red[i]/=prime[j];
}
}
now+=1;
}
int ans=dinic(0,m+n+1);
printf("%d\n",ans);
}
}

P2065 [TJOI2011]卡片的更多相关文章

  1. 【luogu P2065 [TJOI2011]卡片】 假题解

    题目链接:https://www.luogu.org/problemnew/show/P2065 辣鸡匈牙利,没有优化贼鸡儿慢 // luogu-judger-enable-o2 #include & ...

  2. 卡片抽奖插件 CardShow

    这个小项目(卡片秀)是一个卡片抽奖特效插件,用开源项目这样的词语让我多少有些羞愧,毕竟作为一个涉世未深的小伙子,用项目的标准衡量还有很大差距.不过该案例采用 jQuery 插件方式编写,提供配置参数并 ...

  3. 【BZOJ-4698】Sandy的卡片 后缀数组

    4698: Sdoi2008 Sandy的卡片 Time Limit: 10 Sec  Memory Limit: 128 MBSubmit: 140  Solved: 55[Submit][Stat ...

  4. [codevs1743]反转卡片

    [codevs1743]反转卡片 试题描述 [dzy493941464|yywyzdzr原创] 小A将N张卡片整齐地排成一排,其中每张卡片上写了1~N的一个整数,每张卡片上的数各不相同. 比如下图是N ...

  5. 小div布局之卡片堆叠(card-stacking)

    前端的页面布局和各种效果真是让人眼花缭乱,公司的设计师恨不得在一个网站上把前端的布局和样式效果都用一遍. 如何实现下面这种布局效果?我给这种布局效果起了个名字,叫做小div布局之卡片堆叠.然后我百度了 ...

  6. jQuery手机端触摸卡片切换效果

    效果:http://hovertree.com/code/run/jquery/a1gr3gm9.html 可以用手机查看效果. 代码如下: <!doctype html> <htm ...

  7. BZOJ 4698: Sdoi2008 Sandy的卡片

    4698: Sdoi2008 Sandy的卡片 Time Limit: 10 Sec  Memory Limit: 128 MBSubmit: 106  Solved: 40[Submit][Stat ...

  8. 一起来做webgame,《卡片魔兽》(一)基础战斗

    写在前面的话 这不是教程,只是博主在娱乐过程中的一些小结记录.博主水平有限,没有什么高级的东西,只是将一些小的知识点结合一下,做这么一个养成类型的卡片页面游戏(=.=!有点绕).做一个完整的游戏,涉及 ...

  9. css3实现翻页卡片

    css3 实现翻页卡片 应用场景挺多的,比如产品信息展示 效果如下 jsfiddle demo transform perspective backface-visibility transform- ...

随机推荐

  1. linux 6 查看防火墙状态及开启关闭命令

    linux 6 查看防火墙状态及开启关闭命令 https://blog.csdn.net/lv_shijun/article/details/52453882 存在以下两种方式: 一.service方 ...

  2. 基于webpack的vue项目路径别名

    在vue的项目里,我们可以使用../这样的相对路径的方式引用不同目录的组件: import userinfo from '../../../components/userinfo.vue'; 使用.. ...

  3. sklearn中常用数据预处理方法

    1. 标准化(Standardization or Mean Removal and Variance Scaling) 变换后各维特征有0均值,单位方差.也叫z-score规范化(零均值规范化).计 ...

  4. python学习之可变不可变

    在python的数据类型中,整数.字符串.元组是不可变的:而列表.字典是可变的.所以不用C的思维来修改一个整数,它相当于重新定义了一个整数(原来的被覆盖掉了),名字和原来一样,但与前面的同名变量没有一 ...

  5. [转]Knockoutjs快速入门

    本文转自:http://www.cnblogs.com/yinzixin/archive/2012/12/21/2827356.html Knockoutjs是一个JavaScript实现的MVVM框 ...

  6. rails 里js 在production 只合并不压缩等问题,以及assets pipeline 加载js 在指定页面上

    因为刚学rails,试着做了一个小系统操作微信公共帐号, 之后部署的时候遇见了一个问题,整套系统在互联网端访问,非常的慢,而在手机端访问,10s后才会有响应, 打开chrome的调试工具,发现appl ...

  7. UVA 10462 —— Is There A Second Way Left?——————【最小生成树、kruskal、重边】

    Nasa, being the most talented programmer of his time, can’t think things to be so simple. Recently a ...

  8. 让你分分钟学会 javascript 闭包

    闭包,是 javascript 中重要的一个概念,对于初学者来讲,闭包是一个特别抽象的概念,特别是ECMA规范给的定义,如果没有实战经验,你很难从定义去理解它.因此,本文不会对闭包的概念进行大篇幅描述 ...

  9. EasyUI 数据网格 - 设置排序并自定义排序

    数据网格(DataGrid)的所有列可以通过点击列表头来排序.您可以定义哪列可以排序.默认的,列是不能排序的,除非您设置 sortable 属性为 true. 当排序时,数据网格(DataGrid)将 ...

  10. MVC在页面View上获取当前控制器名称、Action名称以及路由参数

    有时候在封装MVC通用控件时需要在页面上获取这些数据. 用以下方法即可: //获取控制器名称: ViewContext.RouteData.Values["controller"] ...