/*
k度限制MST:有一个点的度<=k的MST
poj 1639
要求1号点的度不超过k 求MST
我们先把1号点扔掉 跑MST
假设有sum个连通分支 然后把这sum个分支连到1上
就得到了一个sum度的MST
这里往上连的时候 我们连这个分支里 距离1最近的
然后我们在1上加一条边 (即加一个度)得到sum+1度的MST
这里加边的时候 1连出去的每一条边都试一遍 取最小
假设当前1连到了 i 因为原来是个树 这样一搞就形成一个环
我们现在要删去环里面最长边 来得到更小的ans
我么维护dp[x]代表x到1的路径上权值最大的边的信息
(不包含与1直接相连的边否则删去1的度减1 并不能得到sum+1度的MST)
关键就是维护这个dp[x]
每次找sum+i度的MST之前我们从1dp一遍维护到每个点的max(沿着sum+i-1度的MST)
在树上跑 复杂度就降下来了On可以搞完
方程是 dp[x]=max(dp[from],G[from][x])
当新填的边不比找到的max边大的时候停下
*/
#include<cstdio>
#include<iostream>
#include<cstring>
#include<algorithm>
#include<map>
#define maxn 110
using namespace std;
int n,m,k,num,G[maxn][maxn],vis[maxn][maxn],ans,mt[maxn],wh[maxn],sum,fa[maxn];
map<string,int>f;
struct node{
int u,v,t;
}e[maxn*maxn],dp[maxn*maxn];
int cmp(const node &A,const node &B){
return A.t<B.t;
}
void Add(int from,int to,int dis){
num++;e[num].v=to;
e[num].u=from;
e[num].t=dis;
}
int find(int x){
return x==fa[x]?x:fa[x]=find(fa[x]);
}
void Dfs(int now,int from){
for(int i=;i<=n;i++){
if(i==from)continue;
if(vis[now][i]){
if(dp[i].t!=-){
if(dp[now].t<G[now][i]){
dp[i].t=G[now][i];
dp[i].u=now;dp[i].v=i;
}
else dp[i]=dp[now];
}
Dfs(i,now);
}
}
}
void Kur(){
sort(e+,e++num,cmp);
for(int i=;i<=n;i++)fa[i]=i;
for(int i=;i<=m;i++){
if(e[i].u==||e[i].v==)continue;
if(find(e[i].u)==find(e[i].v))continue;
ans+=e[i].t;fa[find(e[i].u)]=find(e[i].v);
vis[e[i].u][e[i].v]=vis[e[i].v][e[i].u]=;
}
}
int main(){
scanf("%d",&m);f["Park"]=++n;
string A,B;int t;
memset(G,-,sizeof(G));
for(int i=;i<=m;i++){
cin>>A>>B>>t;
if(f[A]==)f[A]=++n;if(f[B]==)f[B]=++n;
Add(f[A],f[B],t);
if(G[f[A]][f[B]]==-)G[f[A]][f[B]]=G[f[B]][f[A]]=t;
else G[f[A]][f[B]]=G[f[B]][f[A]]=min(t,G[f[A]][f[B]]);
}
scanf("%d",&k);
Kur();memset(mt,/,sizeof(mt));
for(int i=;i<=n;i++){
if(G[][i]!=-){
int r=find(i);
if(G[][i]<mt[r]){
mt[r]=G[][i];
wh[r]=i;
}
}
}
for(int i=;i<=n;i++)
if(mt[i]!=mt[]){
sum++;ans+=G[][wh[i]];
vis[][wh[i]]=vis[wh[i]][]=;
}
//得到最小sum度树
for(int i=sum+;i<=k;i++){
dp[].t=-;
for(int j=;j<=n;j++){
if(vis[][j])dp[i].t=-;
else dp[i].t=;
}
Dfs(,-);
int pos,mii=1e9;
for(int j=;j<=n;j++){
if(G[][j]==-)continue;
if(mii>G[][j]-dp[j].t){
pos=j;mii=G[][j]-dp[j].t;
}
}
if(mii>=)break;
vis[][pos]=vis[pos][]=;
vis[dp[pos].u][dp[pos].v]=;
vis[dp[pos].v][dp[pos].u]=;
ans+=mii;
}
printf("Total miles driven: %d\n",ans);
return ;
}

K度限制MST poj 1639的更多相关文章

  1. 度限制最小生成树 POJ 1639 贪心+DFS+prim

    很好的解题报告: http://blog.csdn.net/new_c_yuer/article/details/6365689 注意两点: 1.预处理环中权值最大的边···· 2.可以把去掉度限制后 ...

  2. K - The Unique MST - poj 1679

    题目的意思已经说明了一切,次小生成树... ****************************************************************************** ...

  3. 【POJ 1639】 Picnic Planning (最小k度限制生成树)

    [题意] 有n个巨人要去Park聚会.巨人A和先到巨人B那里去,然后和巨人B一起去Park.B君是个土豪,他家的停车场很大,可以停很多车,但是Park的停车场是比较小.只能停k辆车.现在问你在这个限制 ...

  4. poj 1639 Picnic Planning 度限制mst

    https://vjudge.net/problem/POJ-1639 题意: 有一群人,他们要去某一个地方,每个车可以装无数个人,给出了n条路,包含的信息有路连接的地方,以及路的长度,路是双向的,但 ...

  5. poj 1639 最小k度限制生成树

    题目链接:https://vjudge.net/problem 题意: 给各位看一下题意,算法详解看下面大佬博客吧,写的很好. 参考博客:最小k度限制生成树 - chty - 博客园  https:/ ...

  6. Picnic Planning POJ - 1639(最小k度生成树)

    The Contortion Brothers are a famous set of circus clowns, known worldwide for their incredible abil ...

  7. 最小k度限制生成树

    [题目描述] 给你一个图,n个点,m条边,求一颗生成树满足如下条件: (1)结点1的度不超过k. (2)在(1)条件下所求生成树最小. [算法引入] 最小k度限制生成树,就是指有特殊的某一点的度不能超 ...

  8. POJ 1639 Picnic Planning:最小度限制生成树

    题目链接:http://poj.org/problem?id=1639 题意: 给你一个无向图,n个节点,m条边,每条边有边权. 让你求一棵最小生成树,同时保证1号节点的度数<=k. 题解: 最 ...

  9. poj1639 Picnic Planning,K度限制生成树

    题意: 矮人虽小却喜欢乘坐巨大的轿车,车大到能够装下不管多少矮人.某天,N(N≤20)个矮人打算到野外聚餐.为了集中到聚餐地点,矮人A 要么开车到矮人B 家中,留下自己的轿车在矮人B 家,然后乘坐B ...

随机推荐

  1. fieldset ----- 不常用的HTML标签

    fieldset 元素可将表单内的相关元素分组. <fieldset> 标签将表单内容的一部分打包,生成一组相关表单的字段. 当一组表单元素放到 <fieldset> 标签内时 ...

  2. spring 将配置文件中的值注入 属性

    1.编写配置文件 #债权转让 #默认周期 必须大于0 credit.defaultDuration=1 #最小转让金额(元) credit.minBidAmount=1.00 #最小转让时间 到期时间 ...

  3. 文件下载之ServletOutputStream

    使用response.getOutputStream可以获取ServletOutputStream,从而实现向页面发送流数据.但是需要注意的是,不能使用ajax进行请求,因为这样页面不会有任何反应,可 ...

  4. 【sqli-labs】 less49 GET -Error based -String -Blind -Order By Clause(GET型基于盲注的字符型Order By从句注入)

    都是order by的注入,作者连图片都懒得改了... 注意和整型的区别,前引号用提交的引号闭合,后引号用#注释 http://192.168.136.128/sqli-labs-master/Les ...

  5. bat配置JDK环境变量

    最近总是部署服务器,总是要安装配置JDK,今天就想写个bat来配置JDK的环境变量,首先介绍点bat的小知识 @符号后面的命令不会显示在terminal上 例如: @echo运行时 隐藏命令(不在te ...

  6. 洛谷——P2341 [HAOI2006]受欢迎的牛//POJ2186:Popular Cows

    P2341 [HAOI2006]受欢迎的牛/POJ2186:Popular Cows 题目背景 本题测试数据已修复. 题目描述 每头奶牛都梦想成为牛棚里的明星.被所有奶牛喜欢的奶牛就是一头明星奶牛.所 ...

  7. -------------Django-----URLS路由

    一.相约Django. 1.Django的特点:Django定义了服务分布.路由映射.模板编程.数据处理的一套完整的功能. (1)集成数据访问组件:Django的model层自带数据库ORM组件. ( ...

  8. 第一节:numpy之ndarray对象数据类型及属性

  9. seminar information (Email template)

      The following is an email example of seminar information   **************** Dear all, It is a plea ...

  10. webstorm+nodejs环境中安装淘宝镜像

    用过nodejs的人都知道,从node的官方模板库下载依赖包的时候,经常会遇到“假死”(页面静止不动)的状态,这种速度简直要逼死焦急地等待下班的人.还好咱们万能的淘宝提供了淘宝镜像这么一个不要更好用的 ...