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. PTA天梯赛L2

    L2-001 紧急救援 题意:就是给你一张n<500的图:让你求最短路径,最短路条数,以及路径: 做法,先用dijkstra求最短路,然后dfs找最短路条数,以及点权的最大值: 一般dfs不就可 ...

  2. Python中的抽象基类

    1.说在前头 "抽象基类"这个词可能听着比较"深奥",其实"基类"就是"父类","抽象"就是&quo ...

  3. POJ 1273:Drainage Ditches 网络流模板题

    Drainage Ditches Time Limit: 1000MS   Memory Limit: 10000K Total Submissions: 63339   Accepted: 2443 ...

  4. mnist lenet caffe 测试

    # -*- coding: utf-8 -*-import sysimport numpy as npimport structfrom PIL import Imageprint "hel ...

  5. LVS三种模式区别

    参考文档 http://www.magedu.com/65436.html 名词:CIP 客户端IP地址   VIP:即DS服务器上的代理IP地址,也是客户端访问的执行IP地址 1.NAT模式 ①.客 ...

  6. Nginx和php交互的两种方式

    Unix socket 也叫IPC socket  也就是进程间通信套接字用于同一台主机上的不同进程间交换数据 TCP socket IP socket要利用主机的传输层(tcp),可以用于同一台主机 ...

  7. postfix简单记录

    1.将/etc/postfix/main.cf编辑 myhostname和mydomain等 2.即可测试发送邮件 3.安装DNS功能,其中13和21行改成any yum install bind b ...

  8. go多态

      package main import ( "fmt" ) type Intf interface { process() } type MsgBase struct { id ...

  9. Python 重新加载模块

    每个Python文件中的import modulename只被加载一遍,如果在运行过程中,这个Module被更改了,即使在在interpretor中运行import 语句也没用. 可以使用import ...

  10. codeblocks无法找到编译器问题的三个原因

    出现如下提示: 查看了网上的资料, 1.编译器选择错误 查看路径:setting→compiler Selected compiler选取你已经安装且准备使用的编译器. 2.工程创建时配置错误 查看路 ...