BZOJ4514: [Sdoi2016]数字配对(费用流)
2018-06-17 20:54:20来源:未知 阅读 ()
Submit: 2197 Solved: 859
[Submit][Status][Discuss]
Description
Input
Output
一行一个数,最多进行多少次配对
Sample Input
2 4 8
2 200 7
-1 -2 1
Sample Output
HINT
n≤200,ai≤10^9,bi≤10^5,∣ci∣≤10^5
Source
鸣谢Menci上传
#include<bits/stdc++.h> #define int long long #define getchar() (p1==p2&&(p2=(p1=buf)+fread(buf,1,1<<23,stdin),p1==p2)?EOF:*p1++) using namespace std; const int MAXN=1e5+10; const int INF=1e16+10; char buf[1<<23],*p1=buf,*p2=buf; inline int read() { char c=getchar();int x=0,f=1; while(c<'0'||c>'9'){if(c=='-')f=-1;c=getchar();} while(c>='0'&&c<='9'){x=x*10+c-'0';c=getchar();} return x*f; } int N,S=0,T=23333; int A[MAXN],B[MAXN],C[MAXN],cnt[MAXN]; struct node { int u,v,w,f,nxt; }edge[MAXN]; int head[MAXN],num=0; inline void add_edge(int x,int y,int z,int f) { edge[num].u=x; edge[num].v=y; edge[num].w=z; edge[num].f=f; edge[num].nxt=head[x]; head[x]=num++; } void AddEdge(int x,int y,int z,int f) { add_edge(x,y,z,f); add_edge(y,x,-z,0); } inline int PrimeCut(int x) { int tot=0; for(int i=2;i<=sqrt(x);i++) while(x%i==0) x/=i,tot++; return x>1?tot+1:tot; } namespace Liu { int dis[MAXN],vis[MAXN],Pre[MAXN],ansflow=0,anscost=0; bool SPFA() { queue<int>q; q.push(S); memset(dis,0x3f,sizeof(dis)); memset(vis,0,sizeof(vis)); memset(Pre,0,sizeof(Pre)); dis[S]=0; while(q.size()!=0) { int p=q.front();q.pop(); vis[p]=0; for(int i=head[p];i!=-1;i=edge[i].nxt) { if(edge[i].f>0&&dis[edge[i].v]>dis[p]+edge[i].w) { dis[edge[i].v]=dis[p]+edge[i].w; Pre[edge[i].v]=i; if(!vis[edge[i].v]) q.push(edge[i].v), vis[edge[i].v]=1; } } } return dis[T]<INF; } bool f() { int nowflow=INF; for(int i=T;i!=S;i=edge[Pre[i]].u) nowflow=min(nowflow,edge[Pre[i]].f); if(anscost+nowflow*(-dis[T]) < 0) { ansflow+=anscost/dis[T]; return 0; } for(int i=T;i!=S;i=edge[Pre[i]].u) edge[Pre[i]].f-=nowflow, edge[Pre[i]^1].f+=nowflow; anscost+=nowflow*(-dis[T]); ansflow+=nowflow; // printf("%d\n",ansflow); return 1; } void MCMF() { bool flag=0; while(SPFA()) { if( !f() ) { flag=1; printf("%d",ansflow); break; } } if(flag==0) printf("%d",ansflow); } } void Work() { for(int i=1;i<=N;i++) cnt[i]=PrimeCut(A[i]); for(int i=1;i<=N;i++) cnt[i]&1?AddEdge(S,i,0,B[i]): AddEdge(i+N,T,0,B[i]); for(int i=1;i<=N;i++) { if(cnt[i]&1) { for(int j=1;j<=N;j++) if( (cnt[i]+1==cnt[j]&&A[j]%A[i]==0) || (cnt[j]+1==cnt[i]&&A[i]%A[j]==0) ) AddEdge(i,j+N,-C[i]*C[j],INF); } } Liu::MCMF(); } main() { #ifdef WIN32 freopen("a.in","r",stdin); #else #endif memset(head,-1,sizeof(head)); N=read(); for(int i=1;i<=N;i++) A[i]=read(); for(int i=1;i<=N;i++) B[i]=read(); for(int i=1;i<=N;i++) C[i]=read(); Work(); return 0; }
标签:
版权申明:本站文章部分自网络,如有侵权,请联系:west999com@outlook.com
特别注意:本站所有转载文章言论不代表本站观点,本站所提供的摄影照片,插画,设计作品,如需使用,请与原作者联系,版权归原作者所有
- 括号生成 2020-04-09
- L1-007 念数字 (10分) 2020-03-22
- Qt5小Demo之猜数字游戏 2020-03-19
- 回文数字的验证 2020-03-13
- P1216 [IOI1994]数字三角形 2020-02-14
IDC资讯: 主机资讯 注册资讯 托管资讯 vps资讯 网站建设
网站运营: 建站经验 策划盈利 搜索优化 网站推广 免费资源
网络编程: Asp.Net编程 Asp编程 Php编程 Xml编程 Access Mssql Mysql 其它
服务器技术: Web服务器 Ftp服务器 Mail服务器 Dns服务器 安全防护
软件技巧: 其它软件 Word Excel Powerpoint Ghost Vista QQ空间 QQ FlashGet 迅雷
网页制作: FrontPages Dreamweaver Javascript css photoshop fireworks Flash