[hdu6598]Harmonious Army
网络流建图,首先将所有价值加起来,用最小割考虑要删掉多少个价值:源点向每一个士兵连流量为x的边,士兵向汇点连流量为y的边,每一对关系间连流量为z的边,考虑有方程x1+y2+z=x2+y1+z=a+c,x1+x2=b+c,y1+y2=a+b,由于对称性(其实也不一定要对称),解得x1=x2=(b+c)/2,y1=y2=(a+b)/2,z=(a+c)/2-b,把边都乘以2用总价值减去最大流除以2就可以得到答案

1 #include<bits/stdc++.h>
2 using namespace std;
3 #define N 505
4 #define ll long long
5 struct ji{
6 int nex,to,len;
7 }edge[N*N];
8 queue<int>q;
9 int E,n,m,x,y,a,b,c,d[N],head[N],work[N];
10 void add(int x,int y,int z){
11 edge[E].nex=head[x];
12 edge[E].to=y;
13 edge[E].len=z;
14 head[x]=E++;
15 if (E&1)add(y,x,0);
16 }
17 bool bfs(){
18 q.push(0);
19 for(int i=0;i<=n+1;i++)d[i]=-1;
20 d[0]=0;
21 while (!q.empty()){
22 int k=q.front();
23 q.pop();
24 for(int i=head[k];i!=-1;i=edge[i].nex)
25 if ((edge[i].len)&&(d[edge[i].to]<0)){
26 d[edge[i].to]=d[k]+1;
27 q.push(edge[i].to);
28 }
29 }
30 return d[n+1]>=0;
31 }
32 int dfs(int k,int s){
33 if (k>n)return s;
34 int p;
35 for(int &i=work[k];i!=-1;i=edge[i].nex)
36 if ((edge[i].len)&&(d[edge[i].to]==d[k]+1)){
37 p=dfs(edge[i].to,min(s,edge[i].len));
38 if (p){
39 edge[i].len-=p;
40 edge[i^1].len+=p;
41 return p;
42 }
43 }
44 return 0;
45 }
46 ll dinic(){
47 int k=0;
48 ll ans=0;
49 while (bfs()){
50 for(int i=0;i<=n+1;i++)work[i]=head[i];
51 while (k=dfs(0,0x3f3f3f3f))ans+=k;
52 }
53 return ans;
54 }
55 int main(){
56 while (scanf("%d%d",&n,&m)!=EOF){
57 for(int i=0;i<=n+1;i++)head[i]=-1;
58 ll ans=E=0;
59 for(int i=1;i<=m;i++){
60 scanf("%d%d%d%d%d",&x,&y,&a,&b,&c);
61 add(0,x,b+c);
62 add(0,y,b+c);
63 add(x,n+1,a+b);
64 add(y,n+1,a+b);
65 add(x,y,a+c-2*b);
66 add(y,x,a+c-2*b);
67 ans+=a+b+c;
68 }
69 printf("%lld\n",ans-dinic()/2);
70 }
71 }
[hdu6598]Harmonious Army的更多相关文章
- [2019杭电多校第二场][hdu6598]Harmonious Army(最小割)
		
题目链接:http://acm.hdu.edu.cn/showproblem.php?pid=6598 题意是说一个军队有n人,你可以给他们每个人安排战士或者法师的职业,有m对人有组合技,组合技的信息 ...
 - Harmonious Army
		
Harmonious Army Now, Bob is playing an interesting game in which he is a general of a harmonious arm ...
 - 2019年杭电多校第二场 1008题Harmonious Army(HDU6598+最小割+建图)
		
题目链接 传送门 题意 有\(n\)个士兵,要你给他们分配职业.有\(m\)对关系,对于某一对关系\(u,v\),如果同为勇士则总能力增加\(a\),同法师则增加\(c\),一个勇士一个法师增加\(\ ...
 - hdu多校第二场1008(hdu6598) Harmonious Army 最小割
		
题意: 一个军队有n人,你可以给他们每个人安排战士或者法师的职业,有m对人有组合技,组合技的信息是a,b,c,代表如果这两个人是两个战士,则组合技威力为a,一个战士一个法师,威力为b,其中b=a/4+ ...
 - Hdu 6598 Harmonious Army 最小割
		
N个人 每个人可以是战士/法师 M个组合 每个组合两个人 同是战士+a 同是法师+c 否则+b 对于每一个u,v,a,b,c 建(S,u,a) (u,v,a+c-2*b) (v,T,c) (S,v, ...
 - 2019HDU多校赛第二场 H HDU 6598 Harmonious Army(最小割模型)
		
参考博客https://blog.csdn.net/u013534123/article/details/97142191 #include<bits/stdc++.h> using na ...
 - 2019 Multi-University Training Contest 2 - 1008 - Harmonious Army - 最大流
		
http://acm.hdu.edu.cn/showproblem.php?pid=6598 一开始就觉得是网络流,但是一直都不会怎么建图. 这里要考虑. 每一组边(u,v,a,b,c)建立如下的连接 ...
 - 【HDOJ6598】Harmonious Army(最小割)
		
题意:有n个人,每个人可以从A,B两种职业中选择一种 有m对两人组,如果两个人都是A能获得p的收益,一个A一个B能获得q的收益,都是B能获得r的收益,其中q=p/4+r/3,保证p%4=0,r%3=0 ...
 - 2019 HDU 多校赛第二场 HDU 6598 Harmonious Army 构造最小割模型
		
题意: 有n个士兵,你可以选择让它成为战士还是法师. 有m对关系,u和v 如果同时为战士那么你可以获得a的权值 如果同时为法师,你可以获得c的权值, 如果一个为战士一个是法师,你可以获得b的权值 问你 ...
 
随机推荐
- Java-多态(下)
			
多态 一种类型的多种状态 还有一个小汽车的例子再理解下 汽车接口(相当于父类) package com.oop.demo10; public interface Car { String getNam ...
 - 如何迁移 Spring Boot 到函数计算
			
作者 | 田小单 首先介绍下在本文出现的几个比较重要的概念: 函数计算(Function Compute): 函数计算是一个事件驱动的服务,通过函数计算,用户无需管理服务器等运行情况,只需编写代码并上 ...
 - VS 调试 提示 Lc.exe已退出 代码为-1问题解决方法
			
找到程序项目下Properties文件夹licenses.licx文件,然后右键选择删除就可以了,调试运行正常了 https://jingyan.baidu.com/article/b24f6c822 ...
 - 洛谷4248 AHOI2013差异 (后缀数组SA+单调栈)
			
补博客! 首先我们观察题目中给的那个求\(ans\)的方法,其实前两项没什么用处,直接\(for\)一遍就求得了 for (int i=1;i<=n;i++) ans=ans+i*(n-1); ...
 - res目录下的结构
			
目录 res目录下的结构 drawable开头的文件夹 mipmap开头的文件夹 values开头的文件夹 layout文件夹 使用res目录下的资源 res目录下的结构 如果你展开res目录看一下, ...
 - SpringBoot 后端接收前端传值的方法
			
1.通过HttpServletRequest接收,适用于GET 和 POST请求方式 通过HttpServletRequest对象获取请求参数 @RestController @Reque ...
 - 初识HTML01
			
什么是页面? 页面是基于浏览器的应用程序 页面是数据展示的载体,由浏览器和服务器共同执行产物. 浏览器的功能 向服务器发送用户请求指令 接收并解析数据展示给用户 服务器的功能 存储页面资源 处理并响应 ...
 - Windows10使用技巧
			
Windows10配置技巧 新机配置 "我的电脑"图标设置 在桌面右击鼠标=>个性化=>点击左侧"主题"=>点击相关的设置中的"桌面 ...
 - Java:ConcurrentHashMap类小记-2(JDK7)
			
Java:ConcurrentHashMap类小记-2(JDK7) 对 Java 中的 ConcurrentHashMap类,做一个微不足道的小小小小记,分三篇博客: Java:ConcurrentH ...
 - 普通用户在命令终端使用Python脚本连入校园网
			
普通用户在命令终端使用Python脚本连入校园网 想要连入校园网的步骤: 浏览器输入对应的IP地址,输入账号密码连网: 下载对应软件,输入账号密码连网: 而面对没有界面的服务器,而你又没有root权限 ...