POJ 1149 最大流建图 PIGS

题意:

给出猪圈个数 m 和买家人数 n

然后给出m个猪圈的猪的头数..

接下来 n 行..

给出mm a1 a2 .. a(mm) k 例如 2 1 5 3 表示第i+1个用户 有mm(2) 个猪圈的钥匙 就是有第 a1(1) 个和第 a2(5) 个猪圈的钥匙..还想要买得k头猪..

问最多能够卖出多少头..

思路:

其实就是最大流~

唯一有趣的是建图的过程..

/************************************/

建一个超级源点0..超级汇点n+1

以客户作为节点..

 

超级源点根据第一个拥有猪圈的客户和超级源点连线..容量就是第一个客户累计可以得到多少头猪..

因为第一个打开猪圈的客户可以取得所有的猪..所以超级源点和客户之间的连线容量就表示第一个打开猪圈的人虽能够得到的数量..

然后接下来的每一个人与前一个打开猪圈的人之间连线..容量为INF..因为可以从别的猪圈调猪过来..

然后求得的最大流就是可以卖得的猪的数量..

/**********************************/

Tips:

很喜欢这道题建图的技巧~感觉很有才~~~很聪明~~虽然..可能很基础~

大体就是上面说的了~其中用到了last数组来记录该猪圈上一个拥有钥匙的人~

Code:

View Code
 1 #include <stdio.h>
 2 #include <cstring>
 3 #include <queue>
 4 #include <algorithm>
 5 using namespace std;
 6 #define clr(x) memset(x, 0, sizeof(x))
 7 const int INF = 0x1f1f1f1f;
 8 const int MAXN = 110;
 9 
10 int cap[MAXN][MAXN], flow[MAXN][MAXN];
11 int p[MAXN], a[MAXN];
12 int f, n;
13 
14 void EK(int s, int t)
15 {
16     queue<int> q;
17     memset(flow, 0, sizeof(flow));
18     memset(a, 0, sizeof(a));
19     memset(p, 0, sizeof(p));
20     f = 0;
21     while(1)
22     {
23         memset(a, 0, sizeof(a));
24         a[s] = INF;
25         q.push(s);
26         while(!q.empty())
27         {
28             int u = q.front();
29             q.pop();
30             for(int v = 0; v <= n+1; ++v)
31             if(!a[v] && cap[u][v] > flow[u][v])
32             {
33                 p[v] = u;
34                 q.push(v);
35                 a[v] = a[u] < cap[u][v] - flow[u][v]? a[u]:cap[u][v] - flow[u][v];
36             }
37         }
38         if(a[t] == 0) break;
39         for(int u = t; u != s; u = p[u])
40         {
41             flow[p[u]][u] += a[t];
42             flow[u][p[u]] -= a[t];
43         }
44         f += a[t];
45     }
46 }
47 
48 
49 int main()
50 {
51     int i, j, k;
52     int nn, mm;
53     int tmp, m;
54     int s, t;
55     int h[1010];
56     int last[1010];
57 
58     while(scanf("%d %d", &mm, &nn) != EOF)
59     {
60         clr(cap);
61         clr(last);
62         s = 0, t = nn+1;
63         n = nn;
64 
65         for(i = 1; i <= mm; ++i)
66             scanf("%d", &h[i]);
67 
68         for(i = 1; i <= nn; ++i){
69             scanf("%d", &m);
70             for(j = 0; j < m; ++j){
71                 scanf("%d", &tmp);
72                 if(last[tmp] == 0)
73                     cap[s][i] += h[tmp];
74                 else
75                     cap[last[tmp]][i] = INF;
76                 last[tmp] = i;
77             }
78             scanf("%d", &cap[i][t]);
79         }
80 
81         EK(s, t);
82         printf("%d\n", f);
83     }
84     return 0;
85 }

转载于:https://www.cnblogs.com/Griselda/archive/2012/08/28/2660976.html

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/461742.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

【编译打包】tengine 1.5.2

tengine 官方没有提供rpm包&#xff0c;应网友要求&#xff0c;本文继续提供SRPM 包去掉了不相关的模块&#xff0c;支持平台为 rhel6 系列&#xff0c;适用于Web&#xff0c;LB&#xff0c;cache等场合。编译参数如下./configure \--prefix%{_sysconfdir}/nginx \--sbin-path%…

ARM通识——ARM的7种基本工作模式、37个通用寄存器

以下内容源于朱有鹏嵌入式课程的学习与整理&#xff0c;如有侵权请告知删除。 一、ARM采用32位架构 ARM约定一个Byte是8 bits&#xff0c;一个Halfword是16 bits (2 byte)&#xff0c;一个Word是32 bits (4 byte)。 大部分ARM core 提供ARM 指令集&#xff08;32 bit&#xff0…

软件测试工程师核心竞争力(转)

说明&#xff1a;总结整理来源于网络&#xff0c;并非独立原创 1、传统测试工程师应具备的核心竞争力1.1 测试策略设计能力测试策略设计能力是指&#xff1a;对于各种不同的被测软件&#xff0c;能够快速准确地理解需求&#xff0c;并在有限的时间和资源下&#xff0c;明确测试…

以NFS方式挂载rootfs的设置方法

以下内容源于朱有鹏嵌入式课程的学习与整理&#xff0c;如有侵权请告知删除。 更多详细内容&#xff0c;见Linux中NFS服务器的配置(/etc/export)_天糊土的博客-CSDN博客 网络文件系统&#xff08;NFS&#xff0c;network file system&#xff09;&#xff0c;是一种网络通讯协…

cocos2dx xcode5 创建项目

我的开发环境MacBook Pro OS X 10.9.1&#xff0c;Xcode5。 下载cocos2dx并解压&#xff0c;我使用的版本是2.2.1&#xff0c;3.0beta版本还没出来。 终端cd到cocos2d-x-2.2.1/tools/project-creator&#xff0c;我的全路径是/Users/HanHongmin/Documents/cocos2d-x-2.2.1/too…

poj 3660(floyd 变形)

题意&#xff1a; 有N头牛&#xff0c;每头牛都会有比他强的或者弱的牛&#xff0c;按照牛的强弱排序&#xff0c;问有几头牛的位置是确定的。 5 5&#xff08;n,m&#xff09; 4 3 4 2 3 2 1 2 2 5则4>3>2>5 && 1>2>5故只有2,5是确定的。 1 #include &…

分析根文件系统中的/linuxrc文件(附带busybox的介绍)

以下内容源于朱有鹏嵌入式课程的学习与整理&#xff0c;如有侵权请告知删除。 参考博客 init进程的详解_天糊土的博客-CSDN博客_init进程 busybox详解_linuxarmsummary的博客-CSDN博客 前言 因为uboot给内核传参的bootargs中有“init/linuxrc”这个项目&#xff0c;而由前面的…

Wisconsin Squares [USACO]

这个也不记得了&#xff0c;反正不难 /* ID: zhangyc1 LANG: C TASK: wissqu */ #include <string> #include <cstring> #include <cstdlib> #include <cstdio> #include <cmath> using namespace std;char arrMatrix[4][5]; bool arrNewCow[4][…

CentOS Linux搭建SVN Server配置详解

PS&#xff1a;今天给开发的同事搭建一个公网的SVN Server&#xff0c;google一下&#xff0c;发现下面这篇最详细&#xff0c;就记录下来&#xff0c;重新排版一下。顺便根据自己的使用经验&#xff0c;补充了几个细节和总结。本文配置是基于CentOS 5.x的&#xff0c;但一样适…

bic,orr——设置某些位为0或者1

转载于http://blog.chinaunix.net/uid-28458801-id-4083986.html 一、bic &#xff08;1&#xff09;格式&#xff1a;BIC {条件} {S} 目的寄存器&#xff0c;操作数1&#xff0c;操作数2&#xff1b; &#xff08;2&#xff09;BIC指令用于清除操作数1的某些位&#xff0…

405 Method Not Allowed

当jquery easyui的datagrid插件使用.json文件为数据源&#xff0c;通过非http协议访问【就是直接拖进浏览器查看效果】&#xff0c;能正常加载.json文件并且生成datagrid数据源。但是通过http协议访问示例代码时&#xff0c;无法加载json文件生成datagrid的数据源。 这个是由于…

Eclipse之ANT使用

Ant是Java平台下非常棒的批处理命令执行程序&#xff0c;能非常方便地自动完成编译&#xff0c;测试&#xff0c;打包&#xff0c;部署等等一系列任务&#xff0c;大大提高开发效率。如果你现在还没有开始使用Ant&#xff0c;那就要赶快开始学习使用&#xff0c;使自己的开发水…

idea修改maven项目版本号

1 先安装插件 2 控制台执行命令 mvn build-helper:parse-version versions:set -DnewVersion1.1-SNAPSHOT versions:commit 1.1-SNAPSHOT 为你要修改的版本号 技术交流群&#xff1a; 816227112 有时候命令执行完看不到改变&#xff0c;需要刷新下。 转载于:https://www.cnblo…

str指令

转载于arm汇编—str指令-andyhzw-ChinaUnix博客 &#xff08;1&#xff09;格式&#xff1a;STR{条件} 源寄存器&#xff0c;<存储器地址> &#xff08;2&#xff09;STR指令用于从源寄存器中将一个32位的字数据传送到存储器中。 &#xff08;3&#xff09;指令示例&a…

【POJ】2065 SETI

题意&#xff1a;直接拿样例&#xff0c;37 abc。 a&#xff5e;z表示1&#xff5e;26&#xff0c;*表示0。 x0*1^0x1*1^1x2*1^21(mod 37) x0*2^0x1*2^1x2*2^22(mod 37) x0*3^0x1*3^1x2*3^23(mod 37) 高斯消元&#xff0c;除法x等于乘以x对p的逆元。 1 #include<cstdio>2…

几个国外开源CMS系统比较

CMS是Content Management System的缩写&#xff0c;意为"内容管理系统"。上一下度娘或者放一下Google&#xff0c;全球的CMS系统&#xff0c;不下千个&#xff0c;开源的不下百个&#xff0c;如果只是普通用户&#xff0c;很难有时间和精力去比较那么多的系统优劣。不…

用Python自动生成NBA巨星生涯数据曲线

1.序 之前写过一个用 python 自动生成球员职业生涯数据的程序(原文请关注本人公众号)&#xff0c;大家的反响很好&#xff0c;我也感到很欣慰。有问我怎么做的&#xff0c;如何学 python 的&#xff0c;也有提建议说集成到 web 里面的。 其实最开始我也是考虑到集成到 web 里面…

ldr加载指令,ldr伪指令

转载于ARM中LDR伪指令与LDR加载指令 - Leo Chin - 博客园 一、ldr作为加载指令 &#xff08;1&#xff09;格式为&#xff1a;LDR{条件} 目的寄存器&#xff0c;<存储器地址> &#xff08;2&#xff09;LDR指令用于从存储器中将一个32位的字数据传送到目的寄存器中。 …

桌面秀

介绍一款桌面秀给大家——Rainmeter。个人觉得Rainmeter最大的优点就是能自己编写插件&#xff0c;当然&#xff0c;你也可以去一下网站搜索插件下载。 国内&#xff1a; http://bbs.rainmeter.cn/ 国外&#xff1a; http://rainmeter.net/转载于:https://www.cnblogs.com/HTWo…

javascript函数,值得参考!

2019独角兽企业重金招聘Python工程师标准>>> javascript函数一共可分为五类&#xff1a;   常规函数   数组函数   日期函数   数学函数   字符串函数   1.常规函数   javascript常规函数包括以下9个函数&#xff1a;   (1)alert函数&#xff1a;显…