题意:

第一行输入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. Java入门教程八(面向对象)

    对象概念 一切皆是对象.把现实世界中的对象抽象地体现在编程世界中,一个对象代表了某个具体的操作.一个个对象最终组成了完整的程序设计,这些对象可以是独立存在的,也可以是从别的对象继承过来的.对象之间通过 ...

  2. date成字符串

    //获取当前时间 Date date=new Date(); System.out.println("当前date: "+date); //将时间转化成yyyy-MM-dd格式的字 ...

  3. 全栈前端入门必看 koa2+mysql+vue+vant 构建简单版移动端博客

    koa2+mysql+vue+vant 构建简单版移动端博客 具体内容展示 开始正文 github地址 <br/> 觉得对你有帮助的话,可以star一下^_^必须安装:<br/> ...

  4. 基础JavaScript练习(二)总结

    任务目的 学习与实践JavaScript的基本语法.语言特性 练习使用JavaScript实现简单的排序算法 任务描述 基于上一任务 限制输入的数字在10-100 队列元素数量最多限制为60个,当超过 ...

  5. Ant-design-pro的动态菜单的实现

    页面效果: 如何实现: 1:分别建立SiderMenu和SubMenu组件 2.去and-desingn-vue的官方文档里copy单文件递归菜单的代码https://www.antdv.com/co ...

  6. 安装skimage和cv2

    因为第一次接触这个,所以当时安装的时候,也不是很清楚,现在明白了,记录一下,下次别入坑了. 1.安装skimage模块 skimage的全称是:scikit-image 如果说是这样安装,提示我不成功 ...

  7. DIY 作品 及 维修 不定时更新

    手机电池DIY充电宝 2块,优质手机电池加一个升压ic ,焊上一个 usb 母头.比买的强多了. 还能调压,最高调到24V 可以带白光焊台. 更换手机 SIM/SD 卡二合一 贴上高温胶带,吹下来. ...

  8. vue基础----组件通信(props,$emit,$attrs,$listeners)

    一.父传子,子传孙 1. props 1>在父组件中通过子组件自定义的标签属性来传递数据. 2>在子组件中通过props声明希望用到的数据 <body> <div id= ...

  9. 详解分页组件中查count总记录优化

    1 背景 研究mybatis-plus(以下简称MBP),使用其分页功能时.发现了一个JsqlParserCountOptimize的分页优化处理类,官方对其未做详细介绍,网上也未找到分析该类逻辑的只 ...

  10. vue-autoui自匹配webapi的UI控件

    vue-autoui 是一款基于vue和element扩展的一个自动化UI控件,它主要提供两个控件封装分别是auto-form和auto-grid; 通过这两个控件可以完成大多数的信息输入和查询输出的 ...