题意:

第一行输入m和n,m是猪圈的数量,n是顾客的数量,下面n行 第 i+1行表示第i个顾客 , 输入第一个数字表示有几把猪圈的钥匙,后面输入对应的猪圈,最后一个数字输入顾客想买几头猪.

建图:

设一个源点 s 和一个汇点 t,s 连接猪圈被第一个打开的顾客,权值为猪圈的猪数量,t 与顾客相连,权值为顾客想要的猪的数量,因为题上说迈克会根据下一个顾客的需求来将猪转移到合适的猪圈,所以顾客与同一猪圈排队的后面紧邻的顾客相连,权值为正无穷。

想一下感觉挺对的,s点有无数头猪,但是边的权值为猪圈的数量,说明顾客只能拿这么多,后面紧邻的顾客最然边权是无穷大,但被前面的顾客限制着,虽然顾客可以拿到猪圈里的猪,但是能带到 t 汇点的最多是自己想要的数量,所以求s到t的最大流。

注意:

书上的代码还要开一个数组记录残留网络什么的,我觉得太繁琐,直接在一个 e [ ] [ ]数组里面操作就好。注释的代码是自己建图错误了

关于网络流数组操作

为什么要正向边减去 流,反向边加上 流?

我觉得就像水流一样,从 s 流到 t 后,再沿着原路返回(进行加减操作),如果这个残余网络还有路径可以流,就根据这个残余网络找s到t的路径。

#include<stdio.h>
#include<vector>
#include<string.h>
#include<queue>
using namespace std;
int s,t,n,m,pig[1010],p[120],a[1010],v[1010][120],e[120][120],inf=0x3f3f3f3f;
int bfs()//广搜去找增广路,记录路径
{
int book[110];
for(int i=0; i<=t; i++)
book[i]=0,a[i]=-1;
queue<int>q;
q.push(s);
book[s]=1;
while(!q.empty())
{
int k=q.front();
q.pop();
if(k==t)
return 1;
for(int i=1; i<=t; i++)
{
if(e[k][i]&&!book[i])
{
a[i]=k;
book[i]=1;
q.push(i);
}
}
}
return 0;
}
int main()
{
while(~scanf("%d%d",&n,&m))
{
memset(v,0,sizeof(v));
memset(e,0,sizeof(e));
s=m+1,t=m+2;
int t1,t2;
for(int i=1; i<=n; i++)
scanf("%d",&pig[i]);//几号猪舍有几头猪
int last[1120],num,k;
memset(last,0,sizeof(last));//记录几号猪舍前面一个顾客是谁
for(int i=1;i<=m;i++)//开始建图
{
scanf("%d",&num);
for(int j=0;j<num;j++)
{
scanf("%d",&k);
if(last[k]==0)
e[s][i]+=pig[k];
else
e[last[k]][i]=inf;
last[k]=i;
}
scanf("%d",&e[i][t]);
}//建图完成
// for(int i=1;i<=t;i++)
// {
// for(int j=1;j<=t;j++)
// printf("%d ",e[i][j]);
// printf("\n");
// }
// for(int i=1; i<=m; i++)
// {
// scanf("%d",&t1);
// int k;
// for(k=1; k<=m; k++)
// if(v[i][k]==0)
// break;
// for(int j=1; j<=t1; j++)
// {
// scanf("%d",&t2);
// v[i][k++]=t2;
// }
// scanf("%d",&p[i]);//几号顾客买几只猪
// }
// // for(int i=1; i<=n; i++) //几号猪舍
// {
// for(int j=1; j<=m&&v[i][j]; j++) //第几位顾客
// {
// if(j==1)
// e[s][v[i][j]]+=pig[i];
// else
// e[v[i][j-1]][v[i][j]]=inf;
// }
// }
// for(int i=1; i<=m; i++)
// e[i][t]=p[i];//建图完成 int sum=0;
while(1)
{
int h=t,minn=inf;
if(!bfs())//直到找不到增广路为止
break;
while(a[h]!=-1)//找到所走路径上最短的边
{
if(e[a[h]][h]<minn)
minn=e[a[h]][h];
h=a[h];
}
sum+=minn;
h=t;
while(a[h]!=-1)//减去那个最短的边,再反向加上
{
e[a[h]][h]-=minn;
e[h][a[h]]+=minn;
h=a[h];
}
}
printf("%d\n",sum);
}
return 0;
}

PIGS POJ - 1149网络流(最短增广路---广搜) + 建图的更多相关文章

  1. 网络流 A - PIGS POJ - 1149 最大流

    A - PIGS POJ - 1149 这个题目我开始感觉很难,然后去看了一份题解,写的很好 https://wenku.baidu.com/view/0ad00abec77da26925c5b01c ...

  2. AC日记——pigs poj 1149

    POJ - 1149 思路: 最大流: 代码: #include <cstdio> #include <cstring> #include <iostream> # ...

  3. POJ 1149 网络流 合并建图

    这个题目我敲了一个简单的EK,这不是难点 难点在于建图,按题目的要求 每个猪圈和顾客都建点的话,那也太多了...我看了Edelweiss里面的缩点方法才建好的图,哎,惭愧啊 实际那些猪圈根本不需要单独 ...

  4. POJ 1161 Walls【floyd 以面为点建图】

    题目链接:http://poj.org/problem?id=1161 题目大意: 1.给出m个区域,n个俱乐部点.接下来是n个俱乐部点以及各个区域由什么点围成.求一个区域到各个俱乐部点的距离之和最小 ...

  5. PIGS POJ - 1149(水最大流)

    题意: 有M个猪圈,每个猪圈里初始时有若干头猪.一开始所有猪圈都是关闭的.依次来了N个顾客,每个顾客分别会打开指定的几个猪圈,从中买若干头猪.每个顾客分别都有他能够买的数量的上限.每个顾客走后,他打开 ...

  6. POJ 2226 Muddy Fields(二分匹配 巧妙的建图)

    Description Rain has pummeled the cows' field, a rectangular grid of R rows and C columns (1 <= R ...

  7. poj 1087 A Plug for UNIX(字符串编号建图)

    A Plug for UNIX Time Limit: 1000MS   Memory Limit: 65536K Total Submissions: 14862   Accepted: 5026 ...

  8. poj 1149 Pigs 网络流-最大流 建图的题目(明天更新)-已更新

    题目大意:是有M个猪圈,N个顾客,顾客要买猪,神奇的是顾客有一些猪圈的钥匙而主人MIRKO却没有钥匙,多么神奇?顾客可以在打开的猪圈购买任意数量的猪,只要猪圈里有足够数量的猪.而且当顾客打开猪圈后mi ...

  9. HDU3549 Flow Problem(网络流增广路算法)

    题目链接. 分析: 网络流增广路算法模板题.http://www.cnblogs.com/tanhehe/p/3234248.html AC代码: #include <iostream> ...

随机推荐

  1. 最近做的一个Spring Boot小项目,欢迎大家访问 http://39.97.115.152/

    最近做的一个Spring Boot小项目,欢迎大家访问 http://39.97.115.152/,帮忙找找bug,网站里有源码地址 网站说明 甲壳虫社区(Beetle Community) 一个开源 ...

  2. 数据库及MySQL概述

    #什么是数据 用来描述事物的符号记录.可以是数字.文字.图形等,有多种形式,经过数字化之后存入计算机 #什么是数据库 数据库(Database)就是一个用来存放数据库的仓库,是按照一定的数据结构来组织 ...

  3. unittest实战(三):用例编写

    # coding:utf-8import unittestfrom selenium import webdriverimport timefrom ddt import ddt, data, unp ...

  4. DvaJS入门课

    不管是Vue还是React,他们都没解决组件间的通信和数据流问题.当然,这个说法不是很准确,准确的说法是他们都没很好的处理这些问题.我们是可以用一些烂手段去解决这个问题,但是当应用比较大.数据多的时候 ...

  5. Yuchuan_Linux_C 编程之三 静态库的制作和使用

    一.整体大纲 二.静态库的制作 1)命名规则        lib + 库的名字 + .a        例如:libyuchuan.a2)制作步骤:        1). 生成对应的.o文件 -- ...

  6. 一起了解 .Net Foundation 项目 No.18

    .Net 基金会中包含有很多优秀的项目,今天就和笔者一起了解一下其中的一些优秀作品吧. 中文介绍 中文介绍内容翻译自英文介绍,主要采用意译.如与原文存在出入,请以原文为准. Protobuild Pr ...

  7. Prometheus 监控平台的搭建

    1. 环境准备 两台ubuntu 16.04 服务器内网IP 作用 安装软件 172.16.4.11                 监控的服务端                Prometheus( ...

  8. nes 红白机模拟器 第4篇 linux 手柄驱动支持

    小霸王学习机的真实手柄,实测CPU 占用 80% 接线图: 手柄读时序: joypad.c 驱动: 普通的字符设备驱动. #include <linux/module.h> #includ ...

  9. MySQL 【优化宝典】

    概述 为什么要优化 系统的吞吐量瓶颈往往出现在数据库的访问速度上 随着应用程序的运行,数据库的中的数据会越来越多,处理时间会相应变慢 数据是存放在磁盘上的,读写速度无法和内存相比 如何优化 设计数据库 ...

  10. gulp VS grunt

    前公司代码一直用grunt部署, 偶然了解gulp后:学习gulp并用gulp和grunt在一小项目中实践,对两者之间的用法及区别有所了解后总结这一篇小博文:本文根据实战的项目配置文件,简单讲解实现相 ...