链接

https://www.lydsy.com/JudgeOnline/problem.php?id=4514

思路

EK直接贪心做

<0的时候加上剩余返回

二分图a->b的时候

把b->a也连接上

最后除2

整除和贪心可只知道它是对的

代码

#include <bits/stdc++.h>
#define ll long long
#define iter vector<int>::iterator
using namespace std;
const ll N=5e5+7;
ll read() {
ll x=0,f=1;char s=getchar();
for(;s>'9'||s<'0';s=getchar()) if(s=='-') f=-1;
for(;s>='0'&&s<='9';s=getchar()) x=x*10+s-'0';
return x*f;
}
ll n,S,T,a[2007],b[2007],c[2007];
struct node {
ll u,v,nxt,cap,cost;
}e[N<<1];
ll head[N<<1],tot=1;
void add_edge(ll u,ll v,ll cap,ll cost) {
e[++tot].v=v;
e[tot].u=u;
e[tot].cap=cap;
e[tot].cost=cost;
e[tot].nxt=head[u];
head[u]=tot;
}
void Add(ll u,ll v,ll cap,ll cost) {
// cout<<u<<" "<<v<<"\n";
add_edge(u,v,cap,cost);
add_edge(v,u,0,-cost);
}
ll dis[N];
ll vis[N],frm[N];
bool spfa() {
memset(dis,-0x3f,sizeof(dis));
memset(vis,0,sizeof(dis));
queue<int> q;
q.push(S);
dis[S]=0;
while(!q.empty()) {
ll u=q.front();
q.pop();
vis[u]=0;
for(ll i=head[u];i;i=e[i].nxt) {
ll v=e[i].v;
if(e[i].cap&&dis[v]<dis[u]+e[i].cost) {
dis[v]=dis[u]+e[i].cost;
frm[v]=i;
if(!vis[v]) {
vis[v]=1;
q.push(v);
}
}
}
}
return dis[T]>=-0x3f3f3f3f3f3f3f;
}
ll EK() {
ll flow=0,ans=0;
while(spfa()) {
ll now_flow=0x3f3f3f3f;
for(ll i=frm[T];i;i=frm[e[i].u])
now_flow=min(now_flow,(ll)e[i].cap);
for(ll i=frm[T];i;i=frm[e[i].u]) {
e[i].cap-=now_flow;
e[i^1].cap+=now_flow;
}
if(ans+1LL*now_flow*dis[T]<0) {
ll ok=ans/-dis[T];
return flow+ok;
} else
ans+=now_flow*dis[T],flow+=now_flow;
}
return flow;
}
set<int> dsr[250];
int main() {
freopen("a.in","r",stdin);
n=read();
for(ll i=1;i<=n;++i) a[i]=read();
for(ll i=1;i<=n;++i) b[i]=read();
for(ll i=1;i<=n;++i) c[i]=read();
S=1001,T=1002;
for(ll i=1;i<=n;++i) {
ll tmp=a[i];
for(ll j=2;j*j<=tmp;++j) {
if(tmp%j==0) dsr[i].insert(j);
while(tmp%j==0) tmp/=j;
}
if(tmp!=1) dsr[i].insert(tmp);
}
for(ll i=1;i<=n;++i) Add(S,i,b[i],0);
for(ll i=1;i<=n;++i) Add(i+n,T,b[i],0);
for(ll i=1;i<=n;++i) {
for(ll j=i+1;j<=n;++j) {
ll x=i,y=j;
if(a[x]<a[y]) swap(x,y);
if(a[y]==0) continue;
if(a[x]%a[y]==0) {
if(dsr[x].count(a[x]/a[y])) {
Add(x,y+n,0x3f3f3f3f3f3fLL,c[x]*c[y]);
Add(y,x+n,0x3f3f3f3f3f3fLL,c[x]*c[y]);
}
}
}
}
printf("%lld\n",EK()/2LL);
return 0;
}

4514: [Sdoi2016]数字配对 费用流的更多相关文章

  1. BZOJ 4514: [Sdoi2016]数字配对 [费用流 数论]

    4514: [Sdoi2016]数字配对 题意: 有 n 种数字,第 i 种数字是 ai.有 bi 个,权值是 ci. 若两个数字 ai.aj 满足,ai 是 aj 的倍数,且 ai/aj 是一个质数 ...

  2. BZOJ.4514.[SDOI2016]数字配对(费用流SPFA 二分图)

    BZOJ 洛谷 \(Solution\) 很显然的建二分图后跑最大费用流,但有个问题是一个数是只能用一次的,这样二分图两部分都有这个数. 那么就用两倍的.如果\(i\)可以向\(j'\)连边,\(j\ ...

  3. 【BZOJ4514】[Sdoi2016]数字配对 费用流

    [BZOJ4514][Sdoi2016]数字配对 Description 有 n 种数字,第 i 种数字是 ai.有 bi 个,权值是 ci. 若两个数字 ai.aj 满足,ai 是 aj 的倍数,且 ...

  4. bzoj4514: [Sdoi2016]数字配对--费用流

    看了一眼题目&数据范围,觉得应该是带下界的费用流 原来想拆点变成二分图,能配对的连边,跑二分图,可行性未知 后来看到另外一种解法.. 符合匹配要求的数要满足:质因子的个数相差为1,且两者可整除 ...

  5. 【BZOJ 4514】[Sdoi2016]数字配对 费用流

    利用spfa流的性质,我直接拆两半,正解分奇偶(妙),而且判断是否整除且质数我用的是暴力根号,整洁判断质数个数差一(其他非spfa流怎么做?) #include <cstdio> #inc ...

  6. 图论(费用流):BZOJ 4514 [Sdoi2016]数字配对

    4514: [Sdoi2016]数字配对 Time Limit: 10 Sec  Memory Limit: 128 MBSubmit: 820  Solved: 345[Submit][Status ...

  7. BZOJ 4514: [Sdoi2016]数字配对

    4514: [Sdoi2016]数字配对 Time Limit: 10 Sec  Memory Limit: 128 MBSubmit: 1606  Solved: 608[Submit][Statu ...

  8. 【BZOJ4514】【SDOI2016】数字配对 [费用流]

    数字配对 Time Limit: 10 Sec  Memory Limit: 128 MB[Submit][Status][Discuss] Description 有 n 种数字,第 i 种数字是 ...

  9. [bzoj4514]数字配对[费用流]

    今年SDOI的题,看到他们在做,看到过了一百多个人,然后就被虐惨啦... 果然考试的时候还是打不了高端算法,调了...几天 默默地yy了一个费用流构图: 源连所有点,配对的点连啊,所有点连汇... 后 ...

随机推荐

  1. 记dynamic的一个小坑 -- RuntimeBinderException:“object”未包含“xxx”的定义

    from:http://blog.csdn.net/feiyun0112/article/details/39697955 创建一个控制台程序和一个类库, 在控制台创建一个匿名对象,然后再在类库中访问 ...

  2. SQLAllocHandle

    函数定义: 顾名思义,该函数就是用来分配句柄的,句柄类型参考参数详解. SQLRETURN SQLAllocHandle( SQLSMALLINT     HandleType, SQLHANDLE  ...

  3. sql server得到某个数据库的所有表和所有字段

    select b.name tablename,a.name as columnnamefrom sys.columns a,sys.objects b,sys.types cwhere a.obje ...

  4. 20155228 实验一《Java开发环境的熟悉》实验报告

    20155228 实验一<Java开发环境的熟悉>实验报告 实验内容 使用JDK编译.运行简单的Java程序: 使用IDEA 编辑.编译.运行.调试Java程序. 实验要求 没有Linux ...

  5. 压缩和解压缩(I)

    ZipArchive 压缩方法 -(void)zipArchiveWithFiles { //创建解压缩对象 ZipArchive *zip = [[ZipArchive alloc]init]; / ...

  6. 【2017-2-20】C#运算符

    运算符分类: 1.算术运算符 ⑴+ - * / %(取余,模) /3; Console.Write(d); Console.ReadLine(); 则输出结果为“3”,因为10和3都是int型,dec ...

  7. PLSA主题模型

    主题模型 主题模型这样理解一篇文章的生成过程: 1.          确定文章的K个主题. 2.          重复选择K个主题之一,按主题-词语概率生成词语. 3.          所有词语 ...

  8. 【转】机器学习笔记之(3)——Logistic回归(逻辑斯蒂回归)

    原文链接:https://blog.csdn.net/gwplovekimi/article/details/80288964 本博文为逻辑斯特回归的学习笔记.由于仅仅是学习笔记,水平有限,还望广大读 ...

  9. springboot maven项目,为什么build成功,build path也没错误,project-->clean 也没用,项目上面还是有个红x呢?

    springboot maven项目,为什么build成功,build path也没错误,project-->clean 也没用,项目上面还是有个红x呢? 看错误信息有提示:  Descript ...

  10. WebStorm: The Smartest JavaScript IDE by JetBrains

    WebStorm: The Smartest JavaScript IDE by JetBrains https://www.jetbrains.com/webstorm/?fromMenu