http://acm.hdu.edu.cn/showproblem.php?pid=4309

总结:边可存东西时,可新建一个点x连接u、v,x再连向汇点;

#include<iostream>
#include<cstring>
#include<cstdio>
#include<algorithm>
#include<queue>
using namespace std;
typedef long long ll;
#define pb push_back
const ll INF=1e18;
const int inf=0x3f3f3f3f;
const int M=1e5+;
const int N=1e5+; int a[M],head[M],cur[M],deep[M],s,t,tot,firnum,secnum,thnum;
struct node{
int v,w,nextt;
}e[N];
struct Node{
int u,v,w,cost;
}fir[M],sec[M],th[M];
void addedge(int u,int v,int w){
e[tot].v=v;
e[tot].w=w;
e[tot].nextt=head[u];
head[u]=tot++;
e[tot].v=u;
e[tot].w=;
e[tot].nextt=head[v];
head[v]=tot++; }
bool bfs(){
for(int i=;i<=t;i++)
deep[i]=;
queue<int>que;
que.push(s);
deep[s]=;
while(!que.empty()){
int u=que.front();
que.pop();
for(int i=head[u];~i;i=e[i].nextt){
int v=e[i].v;
if(e[i].w>&&deep[v]==){
deep[v]=deep[u]+;
if(v==t)
return true;
que.push(v);
}
}
}
return deep[t]==?false:true;
}
int dfs(int u,int fl){
if(u==t)
return fl;
int x,res=;
for(int i=cur[u];~i;i=e[i].nextt){
int v=e[i].v;
if(e[i].w>&&deep[v]==deep[u]+){
x=dfs(v,min(fl-res,e[i].w));
res+=x;
e[i].w-=x;
e[i^].w+=x;
if(e[i].w)
cur[u]=;
if(res==fl)
return fl;
}
}
if(res==)
deep[u]=;
return res;
}
int dinic(){
int res=;
while(bfs()){
for(int i=;i<=t;i++)
cur[i]=head[i];
res+=dfs(s,inf);
}
return res;
}
int n,ans,ansmin,mincost;
void init(){
memset(head,-,sizeof(head));
tot=;
mincost=;
}
void solve(int now){
init();
for(int i=;i<=n;i++)
addedge(s,i,a[i]);
for(int i=;i<firnum;i++){
addedge(fir[i].u,n++i,inf);
addedge(n++i,fir[i].v,inf);
addedge(n++i,t,fir[i].w);
}
for(int i=;i<secnum;i++){
addedge(sec[i].u,sec[i].v,inf);
}
for(int i=;i<thnum;i++){
if(now & (<<i) ){
addedge(th[i].u,th[i].v,inf);
mincost+=th[i].cost;
}
else
addedge(th[i].u,th[i].v,);
}
int nowans=dinic();
if(nowans > ans){
ans = nowans;
ansmin = mincost;
}else if(nowans == ans){
ansmin=min(ansmin,mincost);
}
}
int main(){
int m;
while(scanf("%d%d",&n,&m)!=EOF){
ans=;
ansmin=inf;
for(int i=;i<=n;i++){
scanf("%d",&a[i]);
}
firnum=secnum=thnum=;
s=;
t=n+;
for(int u,v,w,p,i=;i<=m;i++){
scanf("%d%d%d%d",&u,&v,&w,&p);
if(p<){
fir[firnum].u=u;
fir[firnum].v=v;
fir[firnum].w=w;
firnum++;
t++;
//addedge(v,t,inf,0); }
else if(p==){
sec[secnum].u=u;
sec[secnum].v=v;
secnum++;
}
else{
th[thnum].u=u;
th[thnum].v=v;
th[thnum].cost=w;
thnum++;
}
}
//cout<<firnum<<":"<<secnum<<":"<<thnum<<endl;
for(int i=;i<=(<<thnum)-;i++)
solve(i); if(ans==)
puts("Poor Heaven Empire");
else
printf("%d %d\n",ans,ansmin);
//puts("");
}
return ;
}

Seikimatsu Occult Tonneru(网络流,状态数(建不建边)不多时,可考虑直接进行枚举的更多相关文章

  1. HDU 4309 Seikimatsu Occult Tonneru

    Seikimatsu Occult Tonneru Time Limit: 6000ms Memory Limit: 32768KB This problem will be judged on HD ...

  2. HDU 4309 Seikimatsu Occult Tonneru (状压 + 网络流)

    题意:输入 n 个城市 m 条边,但是边有三种有向边 a b  c d,第一种是 d 是 0,那么就是一条普通的路,可以通过无穷多人,如果 d < 0,那么就是隧道,这个隧道是可以藏 c 个人, ...

  3. HDU 4309 Seikimatsu Occult Tonneru 网络流量+像缩进

    主题链接:点击打开链接 意甲冠军: 题意:给出一张N(N<=100)个点,M(M<=1000条)边的有向图. 每一个点上都有一些人.每条边有4个属性(u,v,w,p). 这些边分为三种:( ...

  4. HDU 4309 Seikimatsu Occult Tonneru(最大流+二进制枚举)

    http://acm.hdu.edu.cn/showproblem.php?pid=4309 题意: 有n个城市,每个城市有num[i]个居民,有敌人要进行地毯式轰击,居民们要逃到隧道去.现在有隧道, ...

  5. HDU4309-Seikimatsu Occult Tonneru(最大流)

    Seikimatsu Occult Tonneru Time Limit: 12000/6000 MS (Java/Others)    Memory Limit: 32768/32768 K (Ja ...

  6. [NewLife.XCode]反向工程(自动建表建库大杀器)

    NewLife.XCode是一个有10多年历史的开源数据中间件,支持nfx/netstandard,由新生命团队(2002~2019)开发完成并维护至今,以下简称XCode. 整个系列教程会大量结合示 ...

  7. Mac下安装MySQL、Workbench以及建数据库建表最基础操作

    刚用上Mac,什么都不懂,加之以前还没有用过mysql,就想着在Mac上装一个mysql来自己玩,奈何,在网上找了大半天,没有一个干货!愤怒!下面是我安装的过程,希望能帮到和我情况差不多的朋友   首 ...

  8. MySQL建库建表

    一直使用SQL SERVER 数据库:最近项目使用MY SQL感觉还是有一点不适应.不过熟悉之后就会好很多. MY SQL 安装之后会有一个管理工具MySQL Workbench 感觉不太好用,数据库 ...

  9. 【ITOO 2】.NET 动态建库建表:使用SQL字符串拼接方式

    导读:在最近接手的项目(高效云平台)中,有一个需求是要当企业用户注册时,给其动态的新建一个库和表.刚开始接手的时候,是一点头绪都没有,然后查了一些资料,也问了问上一版本的师哥师姐,终于有了点头绪.目前 ...

随机推荐

  1. <kotlin>基础,杂七杂八(亲测有效)

    okhttp class MainActivity : AppCompatActivity() { override fun onCreate(savedInstanceState: Bundle?) ...

  2. HDU 5428:The Factor

    The Factor  Accepts: 101  Submissions: 811  Time Limit: 2000/1000 MS (Java/Others)  Memory Limit: 65 ...

  3. kill -HUP 什么意思?

    参考 74.在DNS系统测试时,设named进程号是53,命令 D 通知进程重读配置文件.A kill –USR2 53 B kill –USR1 53 C kill -INT 63 D kill – ...

  4. PIP一次性导入所有环境和指定镜像源

    镜像源: 阿里云:https://mirrors.aliyun.com/pypi/simple/豆瓣:https://pypi.douban.com/simple/清华大学:https://pypi. ...

  5. bootstrap快速上手

    bootstarp快速上手 首先英文不是非常好无法阅读英文文档的同学的可以翻阅其他团队翻译的官方:http://code.z01.com/ 项目依赖 ,css文件在所有样式之前,js依赖,首先jq,再 ...

  6. webservice wsdl文件标签讲解

    <?xml version="1.0" encoding="utf8"?> <wsdl:definitions targetNamespace ...

  7. .NET技术-6.0. Expression 表达式树 生成 Lambda

    .NET技术-6.0. Expression 表达式树 生成 Lambda public static event Func<Student, bool> myevent; public ...

  8. 2014_csu选拔1_B

    Description Here is no naked girl nor naked runners, but a naked problem: you are to find the K-th s ...

  9. linux下ffmpeg环境搭建记录

    1.Linux下安装yasm 官网下载:http://yasm.tortall.net/Download.html tar -zvxf yasm-1.3.0.tar.gz cd yasm-1.3.0/ ...

  10. keras_yolo3程序框架理解