bzoj4514: [Sdoi2016]数字配对--费用流
看了一眼题目&数据范围,觉得应该是带下界的费用流
原来想拆点变成二分图,能配对的连边,跑二分图,可行性未知
后来看到另外一种解法。。
符合匹配要求的数要满足:质因子的个数相差为1,且两者可整除
因此筛完素数、分解质因子,记录质因子的个数
奇数个分为一类,偶数个分为一类,那么连边一定是奇数向偶数才可以连,而其中能整除的且商为质数的连边
然后源点向奇数的点连边,偶数的点向汇点连边,跑费用流
至于下界,我们先把权值取负
由于是求最小费用,那么当求得费用刚好大于0时
上一次刚好小于零的费用流就是最终的流
答案就是上一次的流量
程序写的不是很简洁。。有些细节比如要开LL值得注意= =
#include<stdio.h> #include<algorithm> #include<string.h> #include<vector> #include<queue> #define LL long long #define INF 0x7fffffff #define maxe 40000*2+10 #define maxn 1000 using namespace std; struct node{ int from,to,flow,next; LL cost; }e[maxe]; int ans,cnt,head[maxn],pre[maxn],vis[maxn]; ],odd[maxn],even[maxn]; LL c[maxn],sum,dis[maxn]; vector<int> prime; void insert(int u, int v, int f, LL c){ e[++cnt].from=u; e[cnt].to=v; e[cnt].flow=f; e[cnt].cost=c; e[cnt].next=head[u]; head[u]=cnt; e[++cnt].from=v; e[cnt].to=u; e[cnt].flow=; e[cnt].cost=-c; e[cnt].next=head[v]; head[v]=cnt; } void init(){ scanf("%d", &n); ; i<=n; i++) scanf("%d", &a[i]); ; i<=n; i++) scanf("%d", &b[i]); ; i<=n; i++) scanf("%lld", &c[i]); } bool judge(int i, int j){ ; int tmp=max(a[i]/a[j], a[j]/a[i]); ; k<prime.size(); k++) if (prime[k]>=tmp) break; ) ; ; } void get_prime(){ memset(notprime,,sizeof(notprime)); ; i<=; i++) if (!notprime[i]){ prime.push_back(i); ; j+=i) notprime[j]=; } } void build(){ odd[]=even[]=; ; i<=n; i++){ ; ; j<prime.size(); j++){ int tmp=a[i]; ) tmp/=prime[j],sum++; } ) odd[++odd[]]=i; ]]=i; } cnt=-; memset(head,-,sizeof(head)); memset(e,,sizeof(e)); ; i<=odd[]; i++) ; j<=even[]; j++) if (judge(odd[i], even[j])) insert(odd[i],even[j],INF,-c[odd[i]]*c[even[j]]); s=n+; t=n+; ; i<=odd[]; i++) insert(s,odd[i],b[odd[i]],); ; i<=even[]; i++) insert(even[i],t,b[even[i]],); } bool spfa(){ memset(pre,-,sizeof(pre)); memset(dis,,sizeof(dis)); queue<int> Q; Q.push(s); dis[s]=; vis[s]=; while (!Q.empty()){ int now=Q.front(); Q.pop(); vis[now]=; ; i=e[i].next){ int v=e[i].to; && dis[v]>dis[now]+e[i].cost){ dis[v]=dis[now]+e[i].cost; pre[v]=i; if (!vis[v]){ vis[v]=; Q.push(v); } } } } ) ; ; } bool flow(){ int f=INF; ; i=pre[e[i^].to]) f=min(f,e[i].flow); ){ ; i=pre[e[i^].to]){ e[i].flow-=f; e[i^].flow+=f; } sum+=dis[t]*f; ans+=f; ; } else{ ans-=(sum/dis[t]); ; } } void work(){ ans=; sum=; while (spfa() && flow()); printf("%d\n", ans); } int main(){ get_prime(); init(); build(); work(); ; }
bzoj4514: [Sdoi2016]数字配对--费用流的更多相关文章
- 【BZOJ4514】[Sdoi2016]数字配对 费用流
[BZOJ4514][Sdoi2016]数字配对 Description 有 n 种数字,第 i 种数字是 ai.有 bi 个,权值是 ci. 若两个数字 ai.aj 满足,ai 是 aj 的倍数,且 ...
- BZOJ 4514: [Sdoi2016]数字配对 [费用流 数论]
4514: [Sdoi2016]数字配对 题意: 有 n 种数字,第 i 种数字是 ai.有 bi 个,权值是 ci. 若两个数字 ai.aj 满足,ai 是 aj 的倍数,且 ai/aj 是一个质数 ...
- BZOJ.4514.[SDOI2016]数字配对(费用流SPFA 二分图)
BZOJ 洛谷 \(Solution\) 很显然的建二分图后跑最大费用流,但有个问题是一个数是只能用一次的,这样二分图两部分都有这个数. 那么就用两倍的.如果\(i\)可以向\(j'\)连边,\(j\ ...
- 【BZOJ 4514】[Sdoi2016]数字配对 费用流
利用spfa流的性质,我直接拆两半,正解分奇偶(妙),而且判断是否整除且质数我用的是暴力根号,整洁判断质数个数差一(其他非spfa流怎么做?) #include <cstdio> #inc ...
- 4514: [Sdoi2016]数字配对 费用流
链接 https://www.lydsy.com/JudgeOnline/problem.php?id=4514 思路 EK直接贪心做 <0的时候加上剩余返回 二分图a->b的时候 把b- ...
- BZOJ4514[Sdoi2016]数字配对——最大费用最大流
题目描述 有 n 种数字,第 i 种数字是 ai.有 bi 个,权值是 ci. 若两个数字 ai.aj 满足,ai 是 aj 的倍数,且 ai/aj 是一个质数, 那么这两个数字可以配对,并获得 ci ...
- 【BZOJ4514】【SDOI2016】数字配对 [费用流]
数字配对 Time Limit: 10 Sec Memory Limit: 128 MB[Submit][Status][Discuss] Description 有 n 种数字,第 i 种数字是 ...
- bzoj4514: [Sdoi2016]数字配对(费用流)
传送门 ps:费用流增广的时候费用和流量打反了……调了一个多小时 每个数只能参与一次配对,那么这就是一个匹配嘛 我们先把每个数分解质因数,记质因子总个数为$cnt_i$,那如果$a_i/a_j$是质数 ...
- [bzoj4514]数字配对[费用流]
今年SDOI的题,看到他们在做,看到过了一百多个人,然后就被虐惨啦... 果然考试的时候还是打不了高端算法,调了...几天 默默地yy了一个费用流构图: 源连所有点,配对的点连啊,所有点连汇... 后 ...
随机推荐
- 异步框架asyn4j的原理
启动时调用init方法 public void init(){ if (!run){ run = true; //工作队列 workQueue = newPriorityBlockingQueue(m ...
- filter应用案例二:权限控制
filter可以用来进行权限控制,比如admin文件夹下的文件只允许管理员进入,那么,可以给admin文件夹加上一个过滤器: 简单代码示例: import java.io.IOException; i ...
- POJ 1635 树的最小表示法/HASH
题目链接:http://poj.org/problem?id=1635 题意:给定两个由01组成的串,0代表远离根,1代表接近根.相当于每个串对应一个有根的树.然后让你判断2个串构成的树是否是同构的. ...
- css -- 元素消失
元素从屏幕消失的方法: A:display:none B:opacity C:visibility D:text-intent:-10000em; E:margin可远可远了 F:position:a ...
- 停靠技术 Dock
C:\Program Files\Borland\Delphi7\Demos\Docking delphi例子 网上文档 http://www.docin.com/p-95543759.html
- zoom作用
转自:http://www.cnblogs.com/top5/archive/2011/07/11/2103343.html css中的zoom的作用1.检查页面的标签是否闭合不要小看这条,也许折腾了 ...
- http://www.cnblogs.com/itsource/p/4266905.html
http://www.cnblogs.com/itsource/p/4266905.html
- 在windows环境中用eclipse搭建hadoop开发环境
1. 整体环境和设置 1.1 hadoo1.0.4集群部署在4台VMWare虚拟机中,这四台虚拟机都是通过NAT模式连接主机 集群中/etc/hosts文件配置 #本机127.0.0.1 localh ...
- HTML5拖放事件(Drag-and-Drop,DnD)
拖放 拖放是一种常见的特性,即抓取对象以后拖到另一个位置.在 HTML5 中,拖放是标准的一部分,任何元素都能够拖放. 拖放是在“拖放源(drag source)”和“拖放目标(drop target ...
- BZOJ2990 : [Ontak2010]Keyboard
考虑从$(1,1)$开始搜索移动方案,每次移动坐标的变化量都是$2$. 如果构成了环,那么环的周长肯定是偶数. 考虑这个环一定要被若干个骨牌覆盖,且还有一个位置是空的. 所以得出环的周长是奇数,矛盾, ...