bzoj1221[HNOI2001] 软件开发 - 网络流24题のNo.10餐巾问题

2024-05-11 23:58

本文主要是介绍bzoj1221[HNOI2001] 软件开发 - 网络流24题のNo.10餐巾问题,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

题目链接:bzoj1221

题目大意:
一项n天的软件开发计划,第i天需要ni个软件开发人员,要为每个开发人员每天提供一块消毒毛巾,这种消毒毛巾使用一天后必须再做消毒处理后才能使用。消毒方式有两种,A种方式的消毒需要a天时间,B种方式的消毒需要b天(b>a),A种消毒方式的费用为每块毛巾fA, B种消毒方式的费用为每块毛巾fB。也可以买一块新毛巾的费用为f(新毛巾是已消毒的,当天可以使用)且f>fA>fB。求最低的总费用。

题解:
最小费用最大流
构图好厉害
把每天拆成两个点 xi yi xi 表示第 i 天用过的餐巾,yi表示第 i 天收到的干净的餐巾。
构图如下:
1、xi-> xi+1 ,流量为 ,费用为 0 ,用过的餐巾可以留到下一天嘛
2、xi-> yi+a+1 ,流量为 ,费用为fA,第一种消毒方式。第 i 天的用完之后餐巾可以经过消毒给第i+a+1天的用。
3、同理第二种消毒方式。xi-> yi+b+1 ,流量为 ,费用为fB。
4、 S ->yi,流量为 ,费用为f,这个表示买毛巾,不是别的天用过的。
5、 S ->xi,流量为 ni ,费用为0; yi -> T ,流量为ni,费用为0;这两条边就是需求的限制。要满足需求的话, yi 就一定有 ni 流出(入), xi 就一定有 ni 流入(出),就是说这天一定有 ni 张餐巾用过。

然后就是跑最小费用最大流了。

#include<cstdio>
#include<cstring>
#include<cstdlib>
#include<iostream>
#include<algorithm>
using namespace std;
#define maxn 2500const int inf=0x7fffffff;
struct node
{int y,c,f,next,ot;//c-费用 f-流量
}a[maxn*6];int len,first[maxn];
int n,S,T,pre[maxn],l[maxn],d[maxn];
int flow[maxn];bool vis[maxn];
int mymin(int x,int y){return (x<y)?x:y;}
void ins(int x,int y,int f,int c)
{len++;int now1=len;a[len].y=y;a[len].c=c;a[len].f=f;a[len].next=first[x];first[x]=len;len++;int now2=len;a[len].y=x;a[len].c=-c;a[len].f=0;a[len].next=first[y];first[y]=len;a[now1].ot=now2;a[now2].ot=now1;
}
int head,tail,list[maxn*10];
int bfs(int st,int ed)
{head=1;tail=1;list[head]=st;memset(d,-1,sizeof(d));memset(pre,-1,sizeof(pre));memset(vis,false,sizeof(vis));pre[st]=0;d[st]=0;flow[st]=inf;vis[st]=true;while (head<=tail){int x=list[head++];for (int k=first[x];k!=-1;k=a[k].next){int y=a[k].y;if (!a[k].f) continue;if (d[y]==-1 || d[y]>d[x]+a[k].c){d[y]=d[x]+a[k].c;flow[y]=mymin(flow[x],a[k].f);pre[y]=x;l[y]=k;if (!vis[y]) {vis[y]=true;list[++tail]=y;}}}vis[x]=false;}if (pre[ed]==-1) return 0;return flow[ed];
}
int MCMF()
{int delta,ans=0;while (delta=bfs(S,T)){ans+=delta*d[T];int x=T;while (x!=S){a[l[x]].f-=delta;a[a[l[x]].ot].f+=delta;x=pre[x];}}return ans;
}
int main()
{//freopen("a.in","r",stdin);//freopen("a.out","w",stdout);int ta,tb,ff,fa,fb,i,r;scanf("%d%d%d%d%d%d",&n,&ta,&tb,&ff,&fa,&fb);S=2*n+1;T=S+1;len=0;memset(first,-1,sizeof(first));for (i=1;i<=n;i++){scanf("%d",&r);ins(S,2*i-1,r,0);ins(2*i,T,r,0);if (i!=n) ins(2*i-1,2*(i+1)-1,inf,0);ins(S,2*i,inf,ff);if (i+ta+1<=n) ins(2*i-1,2*(i+ta+1),inf,fa);if (i+tb+1<=n) ins(2*i-1,2*(i+tb+1),inf,fb);}printf("%d\n",MCMF());return 0;
}

这篇关于bzoj1221[HNOI2001] 软件开发 - 网络流24题のNo.10餐巾问题的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



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

相关文章

Vue3绑定props默认值问题

《Vue3绑定props默认值问题》使用Vue3的defineProps配合TypeScript的interface定义props类型,并通过withDefaults设置默认值,使组件能安全访问传入的... 目录前言步骤步骤1:使用 defineProps 定义 Props步骤2:设置默认值总结前言使用T

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

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

Web服务器-Nginx-高并发问题

《Web服务器-Nginx-高并发问题》Nginx通过事件驱动、I/O多路复用和异步非阻塞技术高效处理高并发,结合动静分离和限流策略,提升性能与稳定性... 目录前言一、架构1. 原生多进程架构2. 事件驱动模型3. IO多路复用4. 异步非阻塞 I/O5. Nginx高并发配置实战二、动静分离1. 职责2

解决升级JDK报错:module java.base does not“opens java.lang.reflect“to unnamed module问题

《解决升级JDK报错:modulejava.basedoesnot“opensjava.lang.reflect“tounnamedmodule问题》SpringBoot启动错误源于Jav... 目录问题描述原因分析解决方案总结问题描述启动sprintboot时报以下错误原因分析编程异js常是由Ja

MySQL 表空却 ibd 文件过大的问题及解决方法

《MySQL表空却ibd文件过大的问题及解决方法》本文给大家介绍MySQL表空却ibd文件过大的问题及解决方法,本文给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友参考... 目录一、问题背景:表空却 “吃满” 磁盘的怪事二、问题复现:一步步编程还原异常场景1. 准备测试源表与数据

解决Nginx启动报错Job for nginx.service failed because the control process exited with error code问题

《解决Nginx启动报错Jobfornginx.servicefailedbecausethecontrolprocessexitedwitherrorcode问题》Nginx启... 目录一、报错如下二、解决原因三、解决方式总结一、报错如下Job for nginx.service failed bec

SysMain服务可以关吗? 解决SysMain服务导致的高CPU使用率问题

《SysMain服务可以关吗?解决SysMain服务导致的高CPU使用率问题》SysMain服务是超级预读取,该服务会记录您打开应用程序的模式,并预先将它们加载到内存中以节省时间,但它可能占用大量... 在使用电脑的过程中,CPU使用率居高不下是许多用户都遇到过的问题,其中名为SysMain的服务往往是罪魁

MySQ中出现幻读问题的解决过程

《MySQ中出现幻读问题的解决过程》文章解析MySQLInnoDB通过MVCC与间隙锁机制在可重复读隔离级别下解决幻读,确保事务一致性,同时指出性能影响及乐观锁等替代方案,帮助开发者优化数据库应用... 目录一、幻读的准确定义与核心特征幻读 vs 不可重复读二、mysql隔离级别深度解析各隔离级别的实现差异

C++ vector越界问题的完整解决方案

《C++vector越界问题的完整解决方案》在C++开发中,std::vector作为最常用的动态数组容器,其便捷性与性能优势使其成为处理可变长度数据的首选,然而,数组越界访问始终是威胁程序稳定性的... 目录引言一、vector越界的底层原理与危害1.1 越界访问的本质原因1.2 越界访问的实际危害二、基

Python多线程应用中的卡死问题优化方案指南

《Python多线程应用中的卡死问题优化方案指南》在利用Python语言开发某查询软件时,遇到了点击搜索按钮后软件卡死的问题,本文将简单分析一下出现的原因以及对应的优化方案,希望对大家有所帮助... 目录问题描述优化方案1. 网络请求优化2. 多线程架构优化3. 全局异常处理4. 配置管理优化优化效果1.