JZOJ 1090. 【SDOI2009】晨跑
题目
略,luogu上有
解析
一眼费用流
然而怎么建图?
首先我们要挖掘题中的限制条件和性质
- 一个点只能经过一次
- 能走的天数最长
- 满足第二条的条件下走过的路程最短
那么显然是最小费用最大流了
对于后两条,我们发现我们求的最大流就要对应天数,最小费用就要对应路程最短
再联系第一条
一个点只能经过一次,那么我们就可以把它拆开成两个点 \(i_1,i_2\) 连流量为 \(1\) 费用为 \(0\) 的边,表示只能流过一次
然后就要使 \(u,v\) 间的连边变为 \(u_2,v_1,1,w\) 和 \(v_1,u_2,0,-w\)
那么源点 \(S\) 就是 \(1\) 拆成的第二个点,汇点 \(T\) 就是 \(n_1\)
最后跑一边 \(MCMF\) 就好了
\(Code\)
#include<cstdio>
#include<iostream>
#include<queue>
#include<cstring>
using namespace std;
const int N = 405 , M = 4e4 + 5;
int n , m , pre[N] , edge[N] , dis[N] , flow[N] , h[N] , vis[N] , tot = 1 , Mincost , Maxflow , S , T;
queue<int> Q;
struct node{
	int to , nxt , w , f;
}e[M << 1];
inline void add(int u , int v , int w , int f){e[++tot] = node{v , h[u] , w , f} , h[u] = tot;}
inline int spfa()
{
	memset(dis , 127 , sizeof dis);
	memset(flow , 127 , sizeof flow);
	memset(vis , 0 , sizeof vis);
	dis[S] = 0 , vis[S] = 1 , Q.push(S) , pre[T] = -1;
	while (!Q.empty())
	{
		int now = Q.front();
		Q.pop();
		for(register int i = h[now]; i; i = e[i].nxt)
		{
			int v = e[i].to;
			if (dis[now] + e[i].f < dis[v] && e[i].w)
			{
				dis[v] = dis[now] + e[i].f , pre[v] = now , edge[v] = i , flow[v] = min(flow[now] , e[i].w);
				if (!vis[v]) vis[v] = 1 , Q.push(v);
			}
		}
		vis[now] = 0;
	}
	return pre[T] != -1;
}
inline void MCMF()
{
	while (spfa())
	{
		Maxflow += flow[T];
		Mincost += dis[T] * flow[T];
		int now = T;
		while (now != S)
		{
			e[edge[now]].w -= flow[T];
			e[edge[now] ^ 1].w += flow[T];
			now = pre[now];
		}
	}
}
int main()
{
	scanf("%d%d" , &n , &m);
	for(register int i = 1; i <= n; i++)
	{
		add(i * 2 - 1 , i * 2 , 1 , 0);
		add(i * 2 , i * 2 - 1 , 0 , 0);
	}
	int u , v , f;
	for(register int i = 1; i <= m; i++)
	{
		scanf("%d%d%d" , &u , &v , &f);
		add(u * 2 , v * 2 - 1 , 1 , f) , add(v * 2 - 1 , u * 2 , 0 , -f);
	}
	S = 2 , T = n * 2 - 1;
	MCMF();
	printf("%d %d\n" , Maxflow , Mincost);
}
JZOJ 1090. 【SDOI2009】晨跑的更多相关文章
- 1877: [SDOI2009]晨跑
		1877: [SDOI2009]晨跑 Time Limit: 4 Sec Memory Limit: 64 MBSubmit: 2007 Solved: 1085[Submit][Status][ ... 
- BZOJ 1877: [SDOI2009]晨跑 费用流
		1877: [SDOI2009]晨跑 Description Elaxia最近迷恋上了空手道,他为自己设定了一套健身计划,比如俯卧撑.仰卧起坐等 等,不过到目前为止,他坚持下来的只有晨跑. 现在给出一 ... 
- bzoj1877: [SDOI2009]晨跑
		挺裸的最小费用最大流... #include<cstdio> #include<queue> #include<cstring> #include<iostr ... 
- BZOJ 1877: [SDOI2009]晨跑( 最小费用最大流 )
		裸的费用流...拆点, 流量限制为1, 最后的流量和费用即答案. ------------------------------------------------------------------- ... 
- BZOJ_1877_[SDOI2009]晨跑_费用流
		BZOJ_1877_[SDOI2009]晨跑_费用流 题意: Elaxia最近迷恋上了空手道,他为自己设定了一套健身计划,比如俯卧撑.仰卧起坐等 等,不过到目前为止,他 坚持下来的只有晨跑. 现在给出 ... 
- BZOJ 3438 小M的作物 & BZOJ 1877 [SDOI2009]晨跑
		我由衷地为我的朋友高兴.哈哈,yian,当你nick name破百上千时,再打“蒟蒻”就会被打的. 好的,说正事吧.请注意,这还是题解.但我发现,网络流实在是太套路了(怪不得这两年几乎销声匿迹).我们 ... 
- 【BZOJ1877】[SDOI2009]晨跑 最小费用最大流
		[BZOJ1877][SDOI2009]晨跑 Description Elaxia最近迷恋上了空手道,他为自己设定了一套健身计划,比如俯卧撑.仰卧起坐等 等,不过到目前为止,他坚持下来的只有晨跑. 现 ... 
- AC日记——[SDOI2009]晨跑 bzoj 1877
		1877: [SDOI2009]晨跑 Time Limit: 4 Sec Memory Limit: 64 MBSubmit: 2131 Solved: 1142[Submit][Status][ ... 
- [SDOI2009]晨跑[最小费用最大流]
		[SDOI2009]晨跑 最小费用最大流的板子题吧 令 \(i'=i+n\) \(i -> i'\) 建一条流量为1费用为0的边这样就不会对答案有贡献 其次是对 \(m\) 条边建 \(u'-& ... 
- 【BZOJ】1877: [SDOI2009]晨跑(最小费用最大流)
		http://www.lydsy.com/JudgeOnline/problem.php?id=1877 费用流做多了,此题就是一眼题. 拆点表示只能经过一次,容量为1,费用为0. 然后再连边即可,跑 ... 
随机推荐
- 关于咪咕视频的m3u8再次解析
			软件和源码 前言 之前写过一片文章: 关于突破咪咕视频付费限制的研究, 但是后来我发现评论说已经不能用了,我知道肯定是api修改了,写这种东西就是这样,不一定什么时候就变化了,然后就用不了了,我懒得继 ... 
- cv2.imread opencv读取不到图片问题
			解决办法 cv2.imread 路径中包含中文,改为英文 其他 这个问题解决了很久,都属于库的问题 
- Redis如何模糊匹配Key值
			Redis模糊匹配Key值 使用Redis的scan代替Keys指令: public Set<String> scan(String matchKey) { Set<String&g ... 
- 不用USB,通过adb无线调试安卓手机页面
			以前真机调试手机页面,都是使用数据线连接手机和电脑,近日身边没有USB数据线,折腾了下如何不依赖数据线只用无线调试手机页面,教程如下. 本教程适用于安卓11以及以上版本.否则应该使用USB数据线连接. ... 
- Django三大主流Web框架(django版本安装-项目创建-应用创建-django三板斧)
			目录 一:python三大主流web框架 1.python三大主流Web框架 2:三大主流web框架特点 二:正常运行Django项目所需要知道的注意事项 1.计算机的名称不能有中文,不然bug在哪你 ... 
- 前端Ui设计常用WEB框架
			目录 一:前端Ui常用框架 1.Bootstrap 2.Font Awesome框架 二.前端其他UI框架 1.Pure 2.bootstrap 3.EasyUI 4.Ant Design 5. La ... 
- xshell+Xftp下载
			1.XShell免费官方网站下载地址:https://www.netsarang.com/zh/all-downloads/ 但是官网的地址贼慢,用以下方法下载 2.可以用这个下(写着中文官网):ht ... 
- Nmap安装
			Nmap(Network Mapper,网络映射器)是一款开放源代码的网络探测和安全审核工具.它被设计用来快速扫描大型网络,包括主机探测与发现.开放的端口情况.操作系统与应用服务指纹识别.WAF识别及 ... 
- uniapp微信小程序 选择日期时间
			一.根据需要点击选择时间日期,效果如下图: (1)新建一个dateTimePicker.js文件 function withData(param){ return param < 10 ? '0 ... 
- [python] 基于Gradio可视化部署机器学习应用
			Gradio是一个开源的Python库,用于构建机器学习和数据科学演示应用.有了Gradio,你可以围绕你的机器学习模型或数据科学工作流程快速创建一个简单漂亮的用户界面.Gradio适用于以下情况: ... 
