POJ训练计划1459_Power Network(网络流最大流/Dinic)

2024-09-04 08:38

本文主要是介绍POJ训练计划1459_Power Network(网络流最大流/Dinic),希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

解题报告

这题建模实在是好建,,,好贱,,,

给前向星给跪了,纯dinic的前向星竟然TLE,sad,,,回头看看优化,,,

矩阵跑过了,2A,sad,,,

/*************************************************************************> File Name:	PowerN.cpp> Author:		_nplus> Mail:	    jun18753370216@gmail.com> Time:		2014年07月19日 星期六 09时30分23秒************************************************************************/#include<cstdio>
#include<cmath>
#include<cstring>
#include<queue>
#include<iostream>
#include<algorithm>
#define inf 99999999
#define N 510
#define M N*N
using namespace std;
int edge[N][N],l[N],n,m,nc,np;
int bfs()
{queue<int >Q;memset(l,-1,sizeof(l));while(!Q.empty())Q.pop();l[n]=0;Q.push(n);while(!Q.empty()){int u=Q.front();Q.pop();for(int i=0; i<=n+1; i++){if(edge[u][i]&&l[i]==-1){l[i]=l[u]+1;Q.push(i);}}}if(l[n+1]>0)return 1;else return 0;
}
int dfs(int x,int f)
{if(x==n+1)return f;int a;for(int i=0; i<=n+1; i++){if(edge[x][i]&&(l[i]==l[x]+1)&&(a=dfs(i,min(edge[x][i],f)))){edge[x][i]-=a;edge[i][x]+=a;return a;}}l[x]=-1;//加上时间优化了15倍,,,sad,,,return 0;
}
int main()
{int i,j,u,v,w;while(~scanf("%d%d%d%d",&n,&np,&nc,&m)){memset(edge,0,sizeof(edge));for(i=0; i<m; i++){while(getchar()!='(');scanf("%d,%d)%d",&u,&v,&w);edge[u][v]=w;}for(i=0; i<np; i++){while(getchar()!='(');scanf("%d)%d",&v,&w);edge[n][v]=w;}for(i=0; i<nc; i++){while(getchar()!='(');scanf("%d)%d",&u,&w);edge[u][n+1]=w;}int a,flow=0;while(bfs()){while(a=dfs(n,inf)){flow+=a;}}printf("%d\n",flow);}
}

写写EK算法,,,竟然比我写的Dinic快,,,看来我的模板问题不少,,,sad,,,
/*************************************************************************> File Name:	PowerN.cpp> Author:		_nplus> Mail:	    jun18753370216@gmail.com> Time:		2014年07月19日 星期六 09时30分23秒************************************************************************/#include<cstdio>
#include<cmath>
#include<cstring>
#include<queue>
#include<iostream>
#include<algorithm>
#define inf 99999999
#define N 510
#define M N*N
using namespace std;
int edge[N][N],pre[N],a[N],n,m,nc,np,flow;
void ek()
{while(1){queue<int >Q;Q.push(n);memset(pre,-1,sizeof(pre));memset(a,0,sizeof(a));a[n]=inf;pre[n]=n;while(!Q.empty()){int u=Q.front();Q.pop();for(int v=0;v<=n+1;v++){if(edge[u][v]&&!a[v]){pre[v]=u;a[v]=min(a[u],edge[u][v]);Q.push(v);}}if(a[n+1])break;}if(!a[n+1])break;for(int u=n+1;u!=n;u=pre[u]){edge[pre[u]][u]-=a[n+1];edge[u][pre[u]]+=a[n+1];}flow+=a[n+1];}
}
int main()
{int i,j,u,v,w;while(~scanf("%d%d%d%d",&n,&np,&nc,&m)){memset(edge,0,sizeof(edge));for(i=0; i<m; i++){while(getchar()!='(');scanf("%d,%d)%d",&u,&v,&w);edge[u][v]=w;}for(i=0; i<np; i++){while(getchar()!='(');scanf("%d)%d",&v,&w);edge[n][v]=w;}for(i=0; i<nc; i++){while(getchar()!='(');scanf("%d)%d",&u,&w);edge[u][n+1]=w;}int a;flow=0;ek();printf("%d\n",flow);}
}


Power Network
Time Limit: 2000MS Memory Limit: 32768K
Total Submissions: 22571 Accepted: 11819

Description

A power network consists of nodes (power stations, consumers and dispatchers) connected by power transport lines. A node u may be supplied with an amount s(u) >= 0 of power, may produce an amount 0 <= p(u) <= p max(u) of power, may consume an amount 0 <= c(u) <= min(s(u),c max(u)) of power, and may deliver an amount d(u)=s(u)+p(u)-c(u) of power. The following restrictions apply: c(u)=0 for any power station, p(u)=0 for any consumer, and p(u)=c(u)=0 for any dispatcher. There is at most one power transport line (u,v) from a node u to a node v in the net; it transports an amount 0 <= l(u,v) <= l max(u,v) of power delivered by u to v. Let Con=Σ uc(u) be the power consumed in the net. The problem is to compute the maximum value of Con. 

An example is in figure 1. The label x/y of power station u shows that p(u)=x and p max(u)=y. The label x/y of consumer u shows that c(u)=x and c max(u)=y. The label x/y of power transport line (u,v) shows that l(u,v)=x and l max(u,v)=y. The power consumed is Con=6. Notice that there are other possible states of the network but the value of Con cannot exceed 6. 

Input

There are several data sets in the input. Each data set encodes a power network. It starts with four integers: 0 <= n <= 100 (nodes), 0 <= np <= n (power stations), 0 <= nc <= n (consumers), and 0 <= m <= n^2 (power transport lines). Follow m data triplets (u,v)z, where u and v are node identifiers (starting from 0) and 0 <= z <= 1000 is the value of l max(u,v). Follow np doublets (u)z, where u is the identifier of a power station and 0 <= z <= 10000 is the value of p max(u). The data set ends with nc doublets (u)z, where u is the identifier of a consumer and 0 <= z <= 10000 is the value of c max(u). All input numbers are integers. Except the (u,v)z triplets and the (u)z doublets, which do not contain white spaces, white spaces can occur freely in input. Input data terminate with an end of file and are correct.

Output

For each data set from the input, the program prints on the standard output the maximum amount of power that can be consumed in the corresponding network. Each result has an integral value and is printed from the beginning of a separate line.

Sample Input

2 1 1 2 (0,1)20 (1,0)10 (0)15 (1)20
7 2 3 13 (0,0)1 (0,1)2 (0,2)5 (1,0)1 (1,2)8 (2,3)1 (2,4)7(3,5)2 (3,6)5 (4,2)7 (4,3)5 (4,5)1 (6,0)5(0)5 (1)2 (3)2 (4)1 (5)4

Sample Output

15
6

Hint

The sample input contains two data sets. The first data set encodes a network with 2 nodes, power station 0 with pmax(0)=15 and consumer 1 with cmax(1)=20, and 2 power transport lines with lmax(0,1)=20 and lmax(1,0)=10. The maximum value of Con is 15. The second data set encodes the network from figure 1.

Source



这篇关于POJ训练计划1459_Power Network(网络流最大流/Dinic)的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/1135535

相关文章

Debian 13升级后网络转发等功能异常怎么办? 并非错误而是管理机制变更

《Debian13升级后网络转发等功能异常怎么办?并非错误而是管理机制变更》很多朋友反馈,更新到Debian13后网络转发等功能异常,这并非BUG而是Debian13Trixie调整... 日前 Debian 13 Trixie 发布后已经有众多网友升级到新版本,只不过升级后发现某些功能存在异常,例如网络转

Python开发简易网络服务器的示例详解(新手入门)

《Python开发简易网络服务器的示例详解(新手入门)》网络服务器是互联网基础设施的核心组件,它本质上是一个持续运行的程序,负责监听特定端口,本文将使用Python开发一个简单的网络服务器,感兴趣的小... 目录网络服务器基础概念python内置服务器模块1. HTTP服务器模块2. Socket服务器模块

Go语言网络故障诊断与调试技巧

《Go语言网络故障诊断与调试技巧》在分布式系统和微服务架构的浪潮中,网络编程成为系统性能和可靠性的核心支柱,从高并发的API服务到实时通信应用,网络的稳定性直接影响用户体验,本文面向熟悉Go基本语法和... 目录1. 引言2. Go 语言网络编程的优势与特色2.1 简洁高效的标准库2.2 强大的并发模型2.

Linux中压缩、网络传输与系统监控工具的使用完整指南

《Linux中压缩、网络传输与系统监控工具的使用完整指南》在Linux系统管理中,压缩与传输工具是数据备份和远程协作的桥梁,而系统监控工具则是保障服务器稳定运行的眼睛,下面小编就来和大家详细介绍一下它... 目录引言一、压缩与解压:数据存储与传输的优化核心1. zip/unzip:通用压缩格式的便捷操作2.

Linux网络配置之网桥和虚拟网络的配置指南

《Linux网络配置之网桥和虚拟网络的配置指南》这篇文章主要为大家详细介绍了Linux中配置网桥和虚拟网络的相关方法,文中的示例代码讲解详细,感兴趣的小伙伴可以跟随小编一起学习一下... 一、网桥的配置在linux系统中配置一个新的网桥主要涉及以下几个步骤:1.为yum仓库做准备,安装组件epel-re

python如何下载网络文件到本地指定文件夹

《python如何下载网络文件到本地指定文件夹》这篇文章主要为大家详细介绍了python如何实现下载网络文件到本地指定文件夹,文中的示例代码讲解详细,感兴趣的小伙伴可以跟随小编一起学习一下...  在python中下载文件到本地指定文件夹可以通过以下步骤实现,使用requests库处理HTTP请求,并结合o

Linux高并发场景下的网络参数调优实战指南

《Linux高并发场景下的网络参数调优实战指南》在高并发网络服务场景中,Linux内核的默认网络参数往往无法满足需求,导致性能瓶颈、连接超时甚至服务崩溃,本文基于真实案例分析,从参数解读、问题诊断到优... 目录一、问题背景:当并发连接遇上性能瓶颈1.1 案例环境1.2 初始参数分析二、深度诊断:连接状态与

Qt实现网络数据解析的方法总结

《Qt实现网络数据解析的方法总结》在Qt中解析网络数据通常涉及接收原始字节流,并将其转换为有意义的应用层数据,这篇文章为大家介绍了详细步骤和示例,感兴趣的小伙伴可以了解下... 目录1. 网络数据接收2. 缓冲区管理(处理粘包/拆包)3. 常见数据格式解析3.1 jsON解析3.2 XML解析3.3 自定义

Linux之计划任务和调度命令at/cron详解

《Linux之计划任务和调度命令at/cron详解》:本文主要介绍Linux之计划任务和调度命令at/cron的使用,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录linux计划任务和调度命令at/cron一、计划任务二、命令{at}介绍三、命令语法及功能 :at

Linux中的计划任务(crontab)使用方式

《Linux中的计划任务(crontab)使用方式》:本文主要介绍Linux中的计划任务(crontab)使用方式,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录一、前言1、linux的起源与发展2、什么是计划任务(crontab)二、crontab基础1、cro