最小树形图--朱刘算法([JSOI2008]小店购物)
题面
Sol
首先设一个 \(0\) 号点,向所有点连边,表示初始价值
显然这个图的一个 \(0\) 为根的最小有向生成树的边权和就是每个买一次的最小价值
再买就一定能优惠(包含 \(0\) 的边)
有向图最小生成树???
朱刘算法
其实正确性不会理论。。
可以说是一个不断调整的过程,从而得到最优解
时间复杂度 \(O(VE)\)
流程:
1.去掉自环
2.先给每个点选择一条最小的入边,并记录连过来的点
3.如果此时有点没有入边(除根以外),那么显然无解
4.算上每个点入边贡献,加入答案
5.如果没有有向环,那么做完结束
6.如果有,缩点,并且把连出去的边都减去连出去那个点的入边,因为贡献算过了
7.存储新图,对新图重复所有操作
Code
# include <bits/stdc++.h>
# define IL inline
# define RG register
# define Fill(a, b) memset(a, b, sizeof(a))
using namespace std;
typedef long long ll;
const int maxn(100005);
const double inf(1e9);
int n, tot, m, cnt, need[maxn], pre[maxn], vis[maxn], id[maxn];
double ans, cost[maxn], prize, inw[maxn];
struct Edge{
int u, v;
double w;
} e[maxn];
IL void DirectedMST(){
RG int num = n, rt = 1, idx;
while(true){
// 初始化
for(RG int i = 1; i <= num; ++i) id[i] = vis[i] = pre[i] = -1, inw[i] = inf;
// 选入边
for(RG int i = 1; i <= cnt; ++i)
if(inw[e[i].v] > e[i].w && e[i].u != e[i].v) inw[e[i].v] = e[i].w, pre[e[i].v] = e[i].u;
pre[rt] = rt, idx = inw[rt] = 0;
// 缩环,统计贡献
for(RG int i = 1; i <= num; ++i){
ans += inw[i];
if(vis[i] == -1){
RG int nw = i;
while(vis[nw] == -1) vis[nw] = i, nw = pre[nw];
if(vis[nw] == i && nw != rt){
id[nw] = ++idx;
for(RG int j = pre[nw]; j != nw; j = pre[j]) id[j] = idx;
}
}
}
// 没有环结束
if(!idx) return;
// 重标号,记录新图
for(RG int i = 1; i <= num; ++i) if(id[i] == -1) id[i] = ++idx;
for(RG int i = 1; i <= cnt; ++i)
e[i].w -= inw[e[i].v], e[i].u = id[e[i].u], e[i].v = id[e[i].v];
num = idx, rt = id[rt];
}
}
int main(){
scanf("%d", &tot), n = 2;
for(RG int i = 1; i <= tot; ++i){
scanf("%lf%d", &cost[n], &need[n]);
if(need[n]) e[++cnt] = (Edge){1, n, cost[n]}, vis[i] = n++;
}
--n, scanf("%d", &m);
for(RG int i = 1, a, b; i <= m; ++i){
scanf("%d%d%lf", &a, &b, &prize);
a = vis[a], b = vis[b];
if(a && b){
cost[b] = min(cost[b], prize);
e[++cnt] = (Edge){a, b, prize};
}
}
for(RG int i = 2; i <= n; ++i) ans += (need[i] - 1) * cost[i];
DirectedMST();
printf("%.2lf\n", ans);
return 0;
}
最小树形图--朱刘算法([JSOI2008]小店购物)的更多相关文章
- 最小树形图——朱刘算法(Edmonds)
定义:一个有向图,存在从某个点为根的,可以到达所有点的一个最小生成树,则它就是最小树形图. 朱刘算法实现过程: [在选出入边集后(看步骤1),若有向图中不存在有向环,说明该图就是最小树形图] 1,选入 ...
- POJ 3164 Command Network 最小树形图 朱刘算法
=============== 分割线之下摘自Sasuke_SCUT的blog============= 最 小树形图,就是给有向带权图中指定一个特殊的点root,求一棵以root为根的有向生成树T, ...
- POJ 3164 Command Network ( 最小树形图 朱刘算法)
题目链接 Description After a long lasting war on words, a war on arms finally breaks out between littlek ...
- poj3164(最小树形图&朱刘算法模板)
题目链接:http://poj.org/problem?id=3164 题意:第一行为n, m,接下来n行为n个点的二维坐标, 再接下来m行每行输入两个数u, v,表点u到点v是单向可达的,求这个有向 ...
- 洛谷P4716 【模板】最小树形图(朱刘算法)
题意 题目链接 Sol 朱刘算法?感觉又是一种神仙贪心算法 大概就是每次贪心的用每个点边权最小的入边更新答案,如果不行的话就缩起来找其他的边 不详细说了,丢链接走人.. #include<bit ...
- POJ - 3164-Command Network 最小树形图——朱刘算法
POJ - 3164 题意: 一个有向图,存在从某个点为根的,可以到达所有点的一个最小生成树,则它就是最小树形图. 题目就是求这个最小的树形图. 参考资料:https://blog.csdn.net/ ...
- bzoj 4349 最小树形图——朱刘算法
题目:https://www.lydsy.com/JudgeOnline/problem.php?id=4349. 学习博客:http://www.cnblogs.com/xzxl/p/7243466 ...
- Luogu2792 [JSOI2008]小店购物
Luogu2792 [JSOI2008]小店购物 重题 bzoj4349 最小树形图 有 \(n\) 个物品,每个物品有价格 \(c_i\) 和所需个数 \(k_i\) ,所有物品必须恰好买 \(k_ ...
- 【LuoguP2792 】[JSOI2008]小店购物(最小树形图)
题目链接 题目描述 小店的优惠方案十分简单有趣: 一次消费过程中,如您在本店购买了精制油的话,您购买香皂时就可以享受2.00元/块的优惠价:如果您在本店购买了香皂的话,您购买可乐时就可以享受1.50元 ...
随机推荐
- Django-工程搭建
-----环境安装 1.创建虚拟环境 mkvirtualenv django_py3_1.11 -p python3 2.安装django pip install django==1.11.11 ...
- 【SpringBoot+Mybatis+thymeleaf报错】Error resolving template "XXX", template might not exist or might not be accessible by any of the configured
解决方法一: 原因:在使用springboot的过程中,如果使用thymeleaf作为模板文件,则要求HTML格式必须为严格的html5格式,必须有结束标签,否则会报错. 在application.y ...
- Go语言string包详解
strings包实现了用于操作字符的简单函数. 查找操作 判断给定字符串s中是否包含子串substr, 找到返回true, 找不到返回false func Contains(s, substr str ...
- html5: 复制到剪贴板 clipboard.js
1.使用clipboard.min.js工具,引用此js 注意事项: IOS微信网页开发中,若使用此工具来开发复制功能,则需要在超链接/按钮上新增 onclick=" " 2.cl ...
- po'j2559 Largest Rectangle in a Histogram 单调栈(递增)
Largest Rectangle in a Histogram Time Limit: 1000MS Memory Limit: 65536K Total Submissions: 29498 ...
- .Net Core 发布异常 An assembly specified in the application
在Core 2.0站点发布时.. DotNet WW.kkkk.dll 报错..报文内容如下: Error: An assembly specified in the application depe ...
- 静态代理,动态代理,Cglib代理详解
一.静态代理 新建一个接口 定义一个玩家方法: package com."".proxy.staticc; public interface Iplayer { public vo ...
- python 脚本备份 mysql 数据库到 OSS
脚本如下: #!/usr/bin/python ########################################################### ################ ...
- split使用和特殊使用(包括截取第一个字符后的数据)
javaScript中关于split()的使用 1.一般使用对一个字符串使用split(),返回一个数组 例子: var testArr = "1,2,3,4,5": var ...
- Java时间的使用
JAVA处理日期时间常用方法: 1.java.util.Calendar Calendar 类是一个抽象类,它为特定瞬间与一组诸如 YEAR.MONTH.DAY_OF_MONTH.HOUR 等 日历字 ...