poj2516Minimum Cost

http://poj.org/problem?id=2516

建图的时候 有个地方写错了 卡了半年。。

题意看了N久啊 有N个店主需要K种物品 有M个供应点 每个供应点有K种物品 其实是算K次最小费用 然后叠加 分解开来这题就是求把某种物品从供应点送到店主那里

多个源点-》多个汇点  所以加一个超级源点 和 超级汇点 源点->M个供应点->N个店主->汇点 所以共有m+n+2条边 套最小费用模板就行了

View Code
  1 #include <iostream>
  2 #include<cstring>
  3 #include<cstdio>
  4 #include<algorithm>
  5 #include<queue>
  6 #define MN 10000
  7 #define MM 10000
  8 #define INF 0xfffffff
  9 using namespace std;
 10 struct node
 11 {
 12     int u,v,cost,cap,next;
 13 }edge[MM];
 14 int head[MN],t,vis[MN],dist[MN],co[55][55][55],sh[55][55],sto[55][55],pp[MN],flow;
 15 void init()
 16 {
 17     t = 0;
 18     memset(head,-1,sizeof(head));
 19 }
 20 void add(int u,int v,int c,int p)
 21 {
 22     edge[t].u = u;
 23     edge[t].v = v;
 24     edge[t].cap = c;
 25     edge[t].cost = p;
 26     edge[t].next = head[u];
 27     head[u] = t++;
 28     edge[t].v = u;
 29     edge[t].u = v;
 30     edge[t].cap = 0;
 31     edge[t].cost = -p;
 32     edge[t].next = head[v];
 33     head[v] = t++;
 34 }
 35 int spfa(int s,int en,int n)
 36 {
 37     int i,j,u,v;
 38     for(i =0 ; i <= n ; i++)
 39     dist[i] = INF;
 40     memset(vis,0,sizeof(vis));
 41     memset(pp,-1,sizeof(pp));
 42     queue<int>q;
 43     q.push(s);
 44     vis[s] = 1;
 45     dist[s] = 0;
 46     while(!q.empty())
 47     {
 48         u = q.front();
 49         q.pop();
 50         vis[u] = 0;
 51         for(i = head[u] ; i != -1 ; i = edge[i].next)
 52         {
 53             v = edge[i].v;
 54             if(edge[i].cap&&dist[v]>dist[u]+edge[i].cost)
 55             {
 56                 dist[v] = dist[u]+edge[i].cost;
 57                 //cout<<dist[v]<<endl;
 58                 pp[v] = i;
 59                 if(!vis[v])
 60                 {
 61                     vis[v] = 1;
 62                     q.push(v);
 63                 }
 64             }
 65         }
 66     }
 67     //cout<<dist[en]<<" ";
 68     if(dist[en]==INF)
 69     return 0;
 70     return 1;
 71 }
 72 int mcmf(int s,int en,int n)
 73 {
 74     int i,minf,minc=0;
 75     while(spfa(s,en,n))
 76     {
 77         minf = INF+1;
 78         for(i = pp[en] ; i != -1 ; i = pp[edge[i].u])
 79         {
 80             if(edge[i].cap<minf)
 81             minf = edge[i].cap;
 82         }
 83         flow+=minf;
 84         for(i = pp[en] ; i != -1 ; i = pp[edge[i].u])
 85         {
 86             edge[i].cap-=minf;
 87             edge[i^1].cap+=minf;
 88         }
 89         minc+=minf*dist[en];
 90     }
 91     return minc;
 92 }
 93 int main()
 94 {
 95     int i,j,n,m,k,g;
 96     while(cin>>n>>m>>k)
 97     {
 98         if(n==0&&m==0&&k==0)
 99         break;
100         int flag = 0,ss=0;
101         for(i = 1; i <= n ; i++)
102             for(j = 1; j <= k ; j++)
103                 cin>>sh[i][j];
104         for(i = 1; i <= m ; i++)
105              for(j = 1; j <= k ; j++)
106                 cin>>sto[i][j];
107         for(i = 1;i <= k ; i++)
108             for(j = 1 ; j <= n ; j++)
109                 for(g = 1; g <= m ; g++)
110                 cin>>co[i][j][g];
111         int s = 0,en = n+m+1;
112         for(i = 1; i <= k ; i++)
113         {
114             init();
115             int sa=0;
116             for(j = 1 ; j <= n ; j++)
117             {
118                add(m+j,en,sh[j][i],0);
119                sa+=sh[j][i];
120             }
121             for(j = 1; j <= m ; j++)
122                 add(s,j,sto[j][i],0);
123             for(j = 1; j <= m ; j++)
124                 for(g = 1 ; g <= n ; g++)
125                     add(j,m+g,INF,co[i][g][j]);
126             flow=0;
127             ss+=mcmf(s,en,n+m+1);
128             if(sa>flow)
129                 break;
130         }
131         if(i==k+1)
132         cout<<ss<<endl;
133         else
134         cout<<"-1\n";
135     }
136     return 0;
137 }

 

转载于:https://www.cnblogs.com/shangyu/archive/2013/03/21/2972399.html

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

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

相关文章

设备驱动框架1——LED驱动框架的分析(核心层)

以下内容源于朱有鹏嵌入式课程的学习与整理&#xff0c;如有侵权请告知删除。 一、驱动框架的含义 1、理解层面1&#xff1a;驱动的分层设计 设备驱动程序&#xff0c;是由内核驱动部分的维护者&#xff0c;以及驱动开发工程师协作完成的。 内核驱动部分的维护者&#xff0c;往…

myeclipse连接mysql怎么调用_myeclipse连接mysql数据库详细步骤

第一步 打开Database windows-prefenrence-showview-DBbrowser ,此时会在工具底部有个DBbrowser &#xff0c;选中它&#xff0c;再它所控制的页面的任意位置 右击new---跳转到一个配置driver的页面 (选择连接方式)图一打开myeclipse然后点击window窗口 点击Open Perspective…

struts2中文件上传

注意点 private File image;//对应的就是表单中文件上传的那个输入域的名称&#xff0c;Struts2框架会封装成File类型的private String imageFileName;// 上传输入域FileName 文件名private String imageContentType;// 上传文件的MIME类型 单个文件 1 package cn.itcast.ac…

虚拟内存管理

MMU 现代操作系统普遍采用虚拟内存管理&#xff08;Virtual Memory Management&#xff09;机制&#xff0c;这需要处理器中的MMU&#xff08;Memory Management Unit&#xff0c;内存管理单元&#xff09;提供支持&#xff0c;本节简要介绍MMU的作用。 首先引入两个概念&…

设备驱动框架2——基于驱动框架写LED驱动(具体操作层)

以下内容源于朱有鹏嵌入式课程的学习与整理&#xff0c;如有侵权请告知删除。 前言 之前写到&#xff0c;九鼎没有使用内核推荐的LED驱动框架。因此&#xff0c;我们打算基于LED驱动框架来编写x210开发板的LED驱动。编写前先要去除九鼎移植的LED驱动&#xff0c;然后配置内核支…

mysql重新用户设置密码_mysql用户密码如何重新设置?

mysql用户密码重新设置停掉MySQL服务&#xff1a;sudo service mysql stop以上命令适用于Ubuntu和Debian。CentOS、Fedora和RHEL下使用mysqld替换mysql。以安全模式启动mysql&#xff1a;sudo mysqld_safe --skip-grant-tables --skip-networking &这样我们就可以直接用roo…

第三章 门电路

1 半导体二极管开关特性 1 二极管的特性可以近似的用3.2.1的PN结方程和图3.2.2伏安特性曲线描述 如下图 二极管近似伏安特性和对应的等效电路 1 a电路表示vcc和r都很小时候二极管正向导通压降和正向电阻都不能忽视 2 b电路表示二极管正向导通电压不可以忽视&#xff0c;但是二…

多个页面同时跳转到一个页面,然后返回到上级页面

第一步&#xff0c;在page_load事件中写入一下代码&#xff1a; string strUrl Request.UrlReferrer.AbsoluteUri;ViewState["Url"] strUrl;第二步&#xff0c;在返回事件中写入一下代码&#xff1a;string strUrl ViewState["Url"].ToString();Respons…

mysql查询数据库日期_mysql如何查询日期与时间

前言&#xff1a;在项目开发中&#xff0c;一些业务表字段经常使用日期和时间类型&#xff0c;而且后续还会牵涉到这类字段的查询。关于日期及时间的查询等各类需求也很多&#xff0c;本篇文章简单讲讲日期及时间字段的规范化查询方法。1.日期和时间类型概览MySQL支持的日期和时…

设备驱动框架3——使用gpiolib完成LED驱动

以下内容源于朱有鹏嵌入式课程的学习整理&#xff0c;如有侵权请告知删除。 一、前言 在实际情况中&#xff0c;很多硬件都要用到GPIO&#xff0c;因此GPIO会复用&#xff1b;如果同一个GPIO被2个驱动同时控制就会出现bug&#xff1b;因此内核提供了gpiolib来统一管理系统中所有…

from PyQt4 import QtGui,QtCore出错-解

from PyQt4 import QtGui,QtCore出错-解今天尝试着安装PyQt写界面&#xff0c;官网下载后发现import出错了&#xff0c;情况如下图&#xff1a;import PyQt4就可以&#xff0c;from PyQt4 import QtCore却不行提示DLL load faied找了下网上有些人说是某些dll文件丢失了&#xf…

多线程条件变量(pthread_cond_wait)用法

条件变量是利用线程间共享得全局变量进行同步的一种机制&#xff0c;主要包括两个动作&#xff1a;一个线程等待“条件变量的条件成立”而挂起&#xff1b;另一个线程使“条件成立”给出条件成立信号。为了防止竞争&#xff0c;条件变量得使用总是和一个互斥锁结合在一起。 1、…

mysql 文件系统规划_Mysql的文件系统规划以及日志配置

Mysql服务器文件系统规划:/dev/sda1 /boot/dev/sda2 //dev/sda3 /home/dev/sda4 /tmp/dev/sdb1 /data/dev/sdc1 /logsda:系统目录 sdb:数据目录 sdc:日志目录linux调度策略&#xff1a;--查看当前的调度策略:less /sys/block/sdb/queue/scheduler[noop] anticipatory deadli…

设备驱动框架4——将驱动集成到内核中

以下内容源于朱有鹏嵌入式课程的学习与整理&#xff0c;如有侵权请告知删除。 驱动集成到内核的概念 驱动开发的步骤一般是&#xff1a; &#xff08;1&#xff09;以模块的形式在内核外部编写与调试 &#xff08;2&#xff09;将调试好的驱动代码集成到kernel中 之前我们编写的…

VirtualBox 虚拟机的网络设置

http://cnzhx.net/blog/virtualbox-vm-network-setting/ 注意&#xff1a;修改第一个网卡虚拟机&#xff0c;此处网络设置添加的是第二个网卡虚拟机&#xff1f;&#xff1f;转载于:https://www.cnblogs.com/ztinass/p/3771225.html

[ios]UITableViewCell自适应高度 【转】

- (CGFloat)tableView:(UITableView *)tableView heightForRowAtIndexPath:(NSIndexPath *)indexPath { // 列寬 CGFloat contentWidth self.tableView.frame.size.width; // 用何種字體進行顯示 UIFont *font [UIFont systemFontOfSize:13]; // 該…

MYSQL存储磁盘创建vgcreate_【转】parted创建硬盘分区并创建LVM

目的&#xff1a;将两个三T的硬盘做成LVM(sdc,sdd)一、parted将硬盘进行分区&#xff1a;1)parted的命令方式Parted 命令分为两种模式&#xff1a;命令行模式和交互模式。1、命令行模式&#xff1a; parted [option] device [command] ,该模式可以直接在命令行下对磁盘进行分区…

Linux设备驱动模型1——设备驱动模型的简介与底层架构

以下内容源于朱有鹏嵌入式课程的学习与整理&#xff0c;如有侵权请告知删除。 一、linux设备驱动模型简介 1、设备驱动模型的含义 设备驱动模型主要体现为以下四个方面&#xff1a; &#xff08;1&#xff09;类class、总线bus、设备device、驱动driver 这四个概念分别对应着四…

例子简单说说C# ref和out

首写从这字段看 ref 就是引用的意思 out当然就是输出了public void getRefStr(ref string str) {str"hello 你好&#xff0c;你变成了Ref了" }public void getOutStr(out string outStr){outStr "hello 你好&#xff0c;你是out输出的值";} protected…

VARIANT变体类型数据

2019独角兽企业重金招聘Python工程师标准>>> 特殊 Variant 是一种特殊的数据类型&#xff0c;除了定长String数据及用户定义类型外&#xff0c;可以包含任何种类的数据。Variant 也可以包含Empty、Error、Nothing及Null等特殊值。可以用VarType函数或TypeName函数来…