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

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

虽然这题数据水

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

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

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

#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);
}
}

最新文章

  1. 同上! 下拉复选框 点击当前的checkbox 选中后面li 添加到指定区域
  2. 【Alpha版本】十天冲刺集结令
  3. 安全快速修改Mysql数据库名的5种方法
  4. openLDAP
  5. (转)SQL SERVER的锁机制(一)——概述(锁的种类与范围)
  6. 3. 星际争霸之php设计模式--简单工厂模式
  7. crontab 误区
  8. Android GestureDetector方法详解
  9. Index Generation
  10. node.js在windows下的学习笔记(6)---安装Express
  11. NYOJ 214 最长上升子序列nlogn
  12. Mac os下安装brew
  13. Notification弹出实现
  14. angular4.0运行在微信端的坑坑洼洼
  15. flutter 解析json
  16. 《c++ concurrency in action》读书笔记1
  17. Kafka吞吐量测试案例
  18. 关于NOIP复赛规模的规定
  19. FM-分解机模型详解
  20. Confluence 6 教程:空间高手

热门文章

  1. C# String.Join用法
  2. Magnum DevStack安装
  3. JavaScript比较运算符——&quot;== != === !==&quot;区别
  4. 我的2015plan
  5. HTML--备忘点
  6. jQuery的选项卡
  7. #include stdio.h(3)
  8. 前端防御XSS
  9. Spring+SpringMVC+Mybatis+Shiro环境搭建之IDEA下搭建Maven项目
  10. 如何让MVC和多层架构和谐并存(一)