双倍经验大法吼

昨天发现不会最小属性图&朱刘算法啊

吓得我赶紧补了一发

朱刘算法模板题

#include <iostream>
#include <cstdio>
#include <cmath>
#include <cstring>
#include <cstdlib>
#include <algorithm>
#define N 55
#define M 2505 using namespace std;
struct edge{
int from,adj,next;double len;
edge(){}
edge(int _from,int _adj,int _next,double _len):from(_from),adj(_adj),next(_next),len(_len){}
} e[M];
int n,g[N],m;
void AddEdge(int u,int v,double w){
e[++m]=edge(u,v,g[u],w);g[u]=m;
} double in[N];
int prep[N];
int vis[N],stamp;
int bl[N],cnt;
double directed_MST(){
double ret=0;
e[0].adj=0;
for (;;){
memset(in,127,sizeof(in));
memset(prep,0,sizeof(prep));
for (int u=1;u<=n;++u)
for (int i=g[u];i;i=e[i].next)
if (e[i].len<in[e[i].adj])
in[e[i].adj]=e[i].len,prep[e[i].adj]=u;
for (int i=1;i<=n;++i) if (prep[i]) ret+=in[i];
memset(vis,0,sizeof(vis));vis[0]=stamp=1;
memset(bl,0,sizeof(bl));cnt=0;
for (int i=1;i<=n;++i)if (!vis[i]){
int u=i;
++stamp;
for (;!vis[u];u=prep[u]) vis[u]=stamp;
if (vis[u]==stamp){
++cnt;
for (;!bl[u];u=prep[u]) bl[u]=cnt;
}
}
if (!cnt) return ret;
for (int i=1;i<=n;++i) if (!bl[i]) bl[i]=++cnt;
int m0=m;
memset(g,0,sizeof(g));m=1;
for (int i=2;i<=m0;++i)
if (bl[e[i].from]!=bl[e[i].adj])
AddEdge(bl[e[i].from],bl[e[i].adj],e[i].len-in[e[i].adj]);
n=cnt;
}
} int need[N];
double mincost[N];
int main(){
scanf("%d",&n);++n;
memset(g,0,sizeof(g));m=1;
int u,v,m0;double tmp;
for (int i=1;i<n;++i){
scanf("%lf%d",&mincost[i],&need[i]);
if (need[i])
AddEdge(n,i,mincost[i]);
}
scanf("%d",&m0);
while (m0--){
scanf("%d%d%lf",&u,&v,&tmp);
if (need[u]&&need[v]){
AddEdge(u,v,tmp);
mincost[v]=min(mincost[v],tmp);
}
}
double sum=0;
for (int i=1;i<=n;++i)
if (need[i])
sum+=mincost[i]*(need[i]-1);
printf("%.2lf\n",sum+directed_MST());
return 0;
}

  

bzoj4349: 最小树形图&&bzoj2260: 商店购物的更多相关文章

  1. bzoj2260: 商店购物 && 4349: 最小树形图

    Description Grant是一个个体户老板,他经营的小店因为其丰富的优惠方案深受附近居民的青睐,生意红火.小店的优惠方案十分简单有趣.Grant规定:在一次消费过程中,如果您在本店购买了精制油 ...

  2. bzoj2260: 商店购物&&4349: 最小树形图

    最小树形图问题啊 最小树形图是撒哩,就是给你一个有向图,确定一个根,要你到达所有点,那棵最短路径树的总边权 做这个用的是朱(jv)刘(lao)算法. 首先假如有多个联通块就无解啦 对应每个点(除了根) ...

  3. [JSOI2008]小店购物 & bzoj4349:最小树形图 最小树形图

    ---题面(洛谷)--- ---题面(bzoj)--- 其实是同一道题,,,样例都一模一样 题解: 一开始看想了好久,,,还想到了最短路和最小生成树,,然而写的时候才意识到最小生成树应该要用无向边 其 ...

  4. bzoj4349: 最小树形图

    最小树形图模板题…… 这种\(O(nm)\)的东西真的能考到么…… #include <bits/stdc++.h> #define N 60 #define INF 1000000000 ...

  5. 【Bzoj2260】【Bzoj4349】商店购物 & 最小树形图

    目录 List Bzoj 2260 商店购物 Description Input Output Sample Input Sample Output Bzoj 4349 最小树形图 Descripti ...

  6. BZOJ 2260 商店购物(最小树形图)

    不会最小树形图的出门左转 其实如果确定每种商品第一件的购买顺序,那么剩下的商品肯定是以最优惠价格购买的. 如何确定各种商品第一件购买时的最小价值呢? 考虑如果购买了\(a_i\)这种商品,那么就能以\ ...

  7. Luogu2792 JSOI2008 小店购物 最小树形图

    传送门 被题意杀 本以为一个种类的物品一定要一起买 看了题解才知道可以先把所有要买的物品买一个,剩下要买的物品就可以得到这个种类的物品能够得到的最大优惠-- 所以现在只需要知道:第一次买所有物品一遍时 ...

  8. 【LuoguP2792 】[JSOI2008]小店购物(最小树形图)

    题目链接 题目描述 小店的优惠方案十分简单有趣: 一次消费过程中,如您在本店购买了精制油的话,您购买香皂时就可以享受2.00元/块的优惠价:如果您在本店购买了香皂的话,您购买可乐时就可以享受1.50元 ...

  9. hdu 4966 GGS-DDU (最小树形图)

    比较好的讲解:http://blog.csdn.net/wsniyufang/article/details/6747392 view code//首先为除根之外的每个点选定一条入边,这条入边一定要是 ...

随机推荐

  1. 如果觉得配置文件没有错,但web-dev-server总是报错,可以在hosts文件里加一行127.0.0.1 localhost

    如果觉得配置文件没有错,但web-dev-server总是报错,可以在hosts文件里加一行127.0.0.1 localhost

  2. js继承《转》

    http://www.jb51.net/article/55540.htm http://www.cnblogs.com/OceanHeaven/p/4965947.html http://www.j ...

  3. PAT 1004. 成绩排名 (20)

    读入n名学生的姓名.学号.成绩,分别输出成绩最高和成绩最低学生的姓名和学号. 输入格式:每个测试输入包含1个测试用例,格式为 第1行:正整数n 第2行:第1个学生的姓名 学号 成绩 第3行:第2个学生 ...

  4. Vs2013中通过Nuget添加不同版本jQuery

    vs2013中如果直接更新jQuery则是2X的版本,为了兼容IE浏览器的,一般都是希望使用jQuery1.x版本的jQuery,则可在调出Nuget的控制台,在控制台输入(此例子是下载jQuery ...

  5. Linux 网络编程详解六(多进程服务器僵尸进程解决方案)

    小结:在点对点p2p程序中,服务器端子程序退出,子进程会主动发送信号,关闭父进程,但是这种模式导致服务器只能支持一个客户端连接,本章节中使用新的框架,子进程退出,不主动发送信号关闭父进程,而是父进程安 ...

  6. mybatis 3.2.8 + log4j2.0.2 控制台输出sql语句

    mybatis3.2.7有一个bug,使用log4j2 (2.0.2)版本时,会找不到类 ,导致启动失败,详见 https://github.com/mybatis/mybatis-3/issues/ ...

  7. easyui layout 折叠后显示标题

    (function($){ var buttonDir = {north:'down',south:'up',east:'left',west:'right'}; $.extend($.fn.layo ...

  8. Autofac中的属性注入功能使用

    使用依赖注入容器时,大部分都是使用构造函数来注入或者是xml配置文件.也有很多支持属性注入.Autofac就是其中一个. 1 为什么要有属性注入? 对于一些使用特频繁的类或者方法,很多类都会用到,那么 ...

  9. Theano2.1.12-基础知识之使用GPU

    来自:http://deeplearning.net/software/theano/tutorial/using_gpu.html using the GPU 想要看GPU的介绍性的讨论和对密集并行 ...

  10. 前端手札--meta标记篇

    通用类: 声明编码 <meta charset='utf-8' /> SEO页面关键词 <meta name="keywords" content="y ...