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

相关文章

Springboot3统一返回类设计全过程(从问题到实现)

《Springboot3统一返回类设计全过程(从问题到实现)》文章介绍了如何在SpringBoot3中设计一个统一返回类,以实现前后端接口返回格式的一致性,该类包含状态码、描述信息、业务数据和时间戳,... 目录Spring Boot 3 统一返回类设计:从问题到实现一、核心需求:统一返回类要解决什么问题?

maven异常Invalid bound statement(not found)的问题解决

《maven异常Invalidboundstatement(notfound)的问题解决》本文详细介绍了Maven项目中常见的Invalidboundstatement异常及其解决方案,文中通过... 目录Maven异常:Invalid bound statement (not found) 详解问题描述可

Android使用java实现网络连通性检查详解

《Android使用java实现网络连通性检查详解》这篇文章主要为大家详细介绍了Android使用java实现网络连通性检查的相关知识,文中的示例代码讲解详细,感兴趣的小伙伴可以跟随小编一起学习一下... 目录NetCheck.Java(可直接拷贝)使用示例(Activity/Fragment 内)权限要求

idea粘贴空格时显示NBSP的问题及解决方案

《idea粘贴空格时显示NBSP的问题及解决方案》在IDEA中粘贴代码时出现大量空格占位符NBSP,可以通过取消勾选AdvancedSettings中的相应选项来解决... 目录1、背景介绍2、解决办法3、处理完成总结1、背景介绍python在idehttp://www.chinasem.cna粘贴代码,出

SpringBoot整合Kafka启动失败的常见错误问题总结(推荐)

《SpringBoot整合Kafka启动失败的常见错误问题总结(推荐)》本文总结了SpringBoot项目整合Kafka启动失败的常见错误,包括Kafka服务器连接问题、序列化配置错误、依赖配置问题、... 目录一、Kafka服务器连接问题1. Kafka服务器无法连接2. 开发环境与生产环境网络不通二、序

SpringSecurity中的跨域问题处理方案

《SpringSecurity中的跨域问题处理方案》本文介绍了跨域资源共享(CORS)技术在JavaEE开发中的应用,详细讲解了CORS的工作原理,包括简单请求和非简单请求的处理方式,本文结合实例代码... 目录1.什么是CORS2.简单请求3.非简单请求4.Spring跨域解决方案4.1.@CrossOr

nacos服务无法注册到nacos服务中心问题及解决

《nacos服务无法注册到nacos服务中心问题及解决》本文详细描述了在Linux服务器上使用Tomcat启动Java程序时,服务无法注册到Nacos的排查过程,通过一系列排查步骤,发现问题出在Tom... 目录简介依赖异常情况排查断点调试原因解决NacosRegisterOnWar结果总结简介1、程序在

解决java.util.RandomAccessSubList cannot be cast to java.util.ArrayList错误的问题

《解决java.util.RandomAccessSubListcannotbecasttojava.util.ArrayList错误的问题》当你尝试将RandomAccessSubList... 目录Java.util.RandomAccessSubList cannot be cast to java.

Apache服务器IP自动跳转域名的问题及解决方案

《Apache服务器IP自动跳转域名的问题及解决方案》本教程将详细介绍如何通过Apache虚拟主机配置实现这一功能,并解决常见问题,本文给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,... 目录​​问题背景​​解决方案​​方法 1:修改 httpd-vhosts.conf(推荐)​​步骤

java反序列化serialVersionUID不一致问题及解决

《java反序列化serialVersionUID不一致问题及解决》文章主要讨论了在Java中序列化和反序列化过程中遇到的问题,特别是当实体类的`serialVersionUID`发生变化或未设置时,... 目录前言一、序列化、反序列化二、解决方法总结前言serialVersionUID变化后,反序列化失