P2065 [TJOI2011]卡片
真·会了网络流,忘了匈牙利
一共两种颜色,很容易想到二分图劈配
虽然这题数据水
但是,数据强的话肯定会卡掉的。
为什么? 我暴力质因数都过了
我们可以在两边的数与质因数相连。然后跑网络流。
#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]卡片的更多相关文章
- 【luogu P2065 [TJOI2011]卡片】 假题解
题目链接:https://www.luogu.org/problemnew/show/P2065 辣鸡匈牙利,没有优化贼鸡儿慢 // luogu-judger-enable-o2 #include & ...
- 卡片抽奖插件 CardShow
这个小项目(卡片秀)是一个卡片抽奖特效插件,用开源项目这样的词语让我多少有些羞愧,毕竟作为一个涉世未深的小伙子,用项目的标准衡量还有很大差距.不过该案例采用 jQuery 插件方式编写,提供配置参数并 ...
- 【BZOJ-4698】Sandy的卡片 后缀数组
4698: Sdoi2008 Sandy的卡片 Time Limit: 10 Sec Memory Limit: 128 MBSubmit: 140 Solved: 55[Submit][Stat ...
- [codevs1743]反转卡片
[codevs1743]反转卡片 试题描述 [dzy493941464|yywyzdzr原创] 小A将N张卡片整齐地排成一排,其中每张卡片上写了1~N的一个整数,每张卡片上的数各不相同. 比如下图是N ...
- 小div布局之卡片堆叠(card-stacking)
前端的页面布局和各种效果真是让人眼花缭乱,公司的设计师恨不得在一个网站上把前端的布局和样式效果都用一遍. 如何实现下面这种布局效果?我给这种布局效果起了个名字,叫做小div布局之卡片堆叠.然后我百度了 ...
- jQuery手机端触摸卡片切换效果
效果:http://hovertree.com/code/run/jquery/a1gr3gm9.html 可以用手机查看效果. 代码如下: <!doctype html> <htm ...
- BZOJ 4698: Sdoi2008 Sandy的卡片
4698: Sdoi2008 Sandy的卡片 Time Limit: 10 Sec Memory Limit: 128 MBSubmit: 106 Solved: 40[Submit][Stat ...
- 一起来做webgame,《卡片魔兽》(一)基础战斗
写在前面的话 这不是教程,只是博主在娱乐过程中的一些小结记录.博主水平有限,没有什么高级的东西,只是将一些小的知识点结合一下,做这么一个养成类型的卡片页面游戏(=.=!有点绕).做一个完整的游戏,涉及 ...
- css3实现翻页卡片
css3 实现翻页卡片 应用场景挺多的,比如产品信息展示 效果如下 jsfiddle demo transform perspective backface-visibility transform- ...
随机推荐
- Java日志组件2---Log4j(org.apache.log4j.Logger)
如果我们在项目中,需要记录的东西并不多,而且也不需要有太多区分,使用jdk的自带Log完全可以解决问题.但是,在开发的过程中,大多数项目都比较大,为方便找到程序的bug,都是需要系统的记录日志的.这里 ...
- hdfs shell命令及java客户端编写
一. hdfs shell命令 可以通过hadoop fs 查看所有的shell命令及其用法. 传文件到hdfs: hadoop fs -put /home/koushengrui/Downloads ...
- IP分片 与 TCP分段的区别 !!!!careful========以及udp中一个包大小究竟为多大合适 ==========三次握手四次挥手细节
首先声明:TCP分片应该称为TCP分段 TCP/IP详解--TCP的分段和IP的分片 分组可以发生在运输层和网络层,运输层中的TCP会分段,网络层中的IP会分片.IP层的分片更多的是为运输层的UDP服 ...
- 虚拟机安装MySQL报** is needed by **错误
执行命令: [root@node1 local]# rpm -ivh mysql-community-server-8.0.12-1.el7.x86_64.rpm 安装MySQL遇到以下问题: err ...
- Oracle基础篇--03DML语言
1.数据准备: --创建表格的 create table dept as select * from scott.dept; create table emp as select * from sco ...
- linux 防止ssh暴力破解密码
收集 /var/log/secure 里面的信息,若是某个IP 链接次数超过一定次数 ,则把此ip记录到/etc/hosts.deny里面 #!/bin/bash #Denyhosts SHELL S ...
- RadControl使用相同的Theme
我們僅須對兩個地方加一些程式碼,就可使所有的RadControl擁用相的Theme,如此一下不但可使Ap內布景主題一致,設計者亦不需要對每個控件做字型,顏色,大小等等瑣碎的設計. App.Xaml.c ...
- JS条件语句优化
1.对多个条件使用Array.includes eg: function test(fruit){ ...
- 1.字符串池化(intern)机制及拓展学习
1.字符串intern机制 用了这么久的python,时刻和字符串打交道,直到遇到下面的情况: a = "hello" b = "hello" print(a ...
- 在CentOS上配置redis服务
#!/bin/sh # # redis Startup script for Redis Server # # chkconfig: - 80 12 # description: Redis is a ...