NYOJ 118 路方案(第二小的跨越)
修路方案
- 描写叙述
 - 
南将军率领着很多部队,它们分别驻扎在N个不同的城市里,这些城市分别编号1~N。因为交通不太便利,南将军准备修路。
如今已经知道哪些城市之间能够修路。假设修路,花费是多少。
如今。军师小工已经找到了一种修路的方案,可以使各个城市都联通起来,并且花费最少。
可是。南将军说,这个修路方案所拼成的图案非常不吉利,想让小工计算一下是否存在第二种方案花费和刚才的方案一样,如今你来帮小工写一个程序算一下吧。
- 输入
 - 
第一行输入一个整数T(1<T<20)。表示測试数据的组数
每组測试数据的第一行是两个整数V,E,(3<V<500,10<E<200000)分别表示城市的个数和城市之间路的条数。数据保证全部的城市都有路相连。
随后的E行,每行有三个数字A B L。表示A号城市与B号城市之间修路花费为L。 - 输出
 - 对于每组測试数据输出Yes或No(假设存在两种以上的最小花费方案则输出Yes,假设最小花费的方案仅仅有一种,则输出No)
 - 例子输入
 - 
2
3 3
1 2 1
2 3 2
3 1 3
4 4
1 2 2
2 3 2
3 4 2
4 1 2 - 例子输出
 - 
No
Yes - 
Prim+次小生成树。
 - 
次小生成树的两种算法:
算法1、step 1. 先用prim求出最小生成树T.
在prim的同一时候。用一个矩阵max[u][v] 记录 在T中连结随意两点u,v的唯一的
路中权值最大的那条边的权值. (注意这里).
这是非常easy做到的。由于prim是每次增加一个结点s, 而设已经标号了的结点
集合为W, 则W中全部的结点到s的路中的最大权值的边就是当前增加的这条边.
step 1 用时 O(V^2).
step 2. 枚举全部不在T中的边uv, 增加边uv则必定替换权为max[u][v]的边。 算法2、先用prim求出最小生成树T。
枚举T中的每一条边,把它删除,求剩下的图的最小生成树。 选全部枚举得到的生成树中的最小的那一个。 - 
AC码:
 - 
#include<stdio.h>
#include<string.h>
#define INF 99999999
int G[505][505],visit[505],lowcost[505];
int repair[505][505],pre[505],f[505][505];
int main()
{
int T,v,e,a,b,cost,MinTree,ans,i,j,k,min;
scanf("%d",&T);
while(T--)
{
scanf("%d%d",&v,&e);
//memset(G,INF,sizeof(G)); // 对矩阵G赋值,仅仅能赋为0或-1,假设赋为INF,提交不成功
for(i=0;i<=v;i++)
{
for(j=0;j<=v;j++)
G[i][j]=INF;
}
memset(repair,0,sizeof(repair)); for(i=0;i<e;i++)
{
scanf("%d%d%d",&a,&b,&cost);
G[a][b]=G[b][a]=cost;
// 把该边初始为可修状态
repair[a][b]=repair[b][a]=1; // repair:修
} // Prim算法生成最小树
memset(visit,0,sizeof(visit));
memset(f,0,sizeof(f));
for(i=1;i<=v;i++)
{
lowcost[i]=G[1][i]; // 初始化lowcost的值
pre[i]=1; // 辅助数组
}
visit[1]=1;
k=1;
MinTree=0;
for(i=1;i<=v;i++)
{
min=INF;
for(j=1;j<=v;j++)
{
if(!visit[j]&&min>lowcost[j])
{
min=lowcost[j];
k=j;
}
}
if(min==INF)
break;
repair[pre[k]][k]=repair[k][pre[k]]=0;
MinTree+=min;
visit[k]=1;
for(j=1;j<=v;j++)
{
if(visit[j])
f[k][j]=f[j][k]=f[j][pre[k]]>G[pre[k]][k]?f[j][pre[k]]:G[pre[k]][k];
if(!visit[j]&&G[k][j]<lowcost[j])
{
lowcost[j]=G[k][j];
pre[j]=k;
}
}
} // 再求次小生成树
ans=INF;
for(i=1;i<=v;i++)
{
for(j=1;j<=v;j++)
{
if(repair[i][j])
ans=ans<(MinTree-f[i][j]+G[i][j])?ans:(MinTree-f[i][j]+G[i][j]);
}
}
if(ans==MinTree)
printf("Yes\n");
else
printf("No\n");
}
return 0;
} 
 
版权声明:本文博主原创文章,博客,未经同意不得转载。
NYOJ 118 路方案(第二小的跨越)的更多相关文章
- NYOJ 118 修路方案
		
修路方案 时间限制:3000 ms | 内存限制:65535 KB 难度:5 描述 南将军率领着许多部队,它们分别驻扎在N个不同的城市里,这些城市分别编号1~N,由于交通不太便利,南将军准备修 ...
 - nyoj 118 修路方案(最小生成树删边求多个最小生成树)
		
修路方案 时间限制:3000 ms | 内存限制:65535 KB 难度:5 描述 南将军率领着许多部队,它们分别驻扎在N个不同的城市里,这些城市分别编号1~N,由于交通不太便利,南将军准备修 ...
 - codevs——1700 施工方案第二季
		
1700 施工方案第二季 2012年市队选拔赛北京 时间限制: 1 s 空间限制: 128000 KB 题目等级 : 黄金 Gold 题解 题目描述 Description c国边防 ...
 - codevs 1700 施工方案第二季
		
1700 施工方案第二季 2012年市队选拔赛北京 时间限制: 1 s 空间限制: 128000 KB 题目等级 : 黄金 Gold 题解 题目描述 Description c国边防 ...
 - HDOJ 2561. 第二小整数  第k大问题
		
第二小整数 Time Limit: 3000/1000 MS (Java/Others) Memory Limit: 32768/32768 K (Java/Others) Total Subm ...
 - HDU-2561                                      第二小整数
		
http://acm.hdu.edu.cn/showproblem.php?pid=2561 第二小整数 Time Limit: 3000/1000 MS (Java/Others) Memor ...
 - HDOJ/HDU 2561 第二小整数(水题~排序~)
		
Problem Description 求n个整数中倒数第二小的数. 每一个整数都独立看成一个数,比如,有三个数分别是1,1,3,那么,第二小的数就是1. Input 输入包含多组测试数据. 输入的第 ...
 - Python之路【第二十篇】:待更新中.....
		
Python之路[第二十篇]:待更新中.....
 - 基于visual Studio2013解决算法导论之015第二小元素
		
 题目 查找第二小元素 解决代码及点评 #include <stdio.h> #include <stdlib.h> #include <malloc.h> ...
 
随机推荐
- hbase基本概念和hbase shell经常使用命令使用方法
			
HBase是一个分布式的.面向列的开源数据库,源于google的一篇论文<bigtable:一个结构化数据的分布式存储系统>.HBase是Google Bigtable的开源实现,它利用H ...
 - poj2528(线段树)
			
题目连接:http://poj.org/problem?id=2528 题意:在墙上贴海报,海报可以互相覆盖,问最后可以看见几张海报 分析:离散化+线段树,这题因为每个数字其实表示的是一个单位长度,因 ...
 - V5
			
系统设置--关于手机--版本号点5下--进去开发模式--打开开发选项--打开USB调试.然后在连接第三方助手软件 http://bbs.ztehn.com/thread-19037-1-1.html
 - 《Android内核剖析》读书笔记 第13章 View工作原理【View重绘过程】
			
计算视图大小的过程(Measure) 视图大小,准确的来说应该是指视图的布局大小:我们在layout.xml中为每个UI控件设置的layout_width/layout_height两个属性被用来设置 ...
 - Oracle中decode函数 列变成行
			
create table t_class(c_Id number(10) primary key ,stuName varchar2(50), --人名c_Name varchar2(50), ...
 - Wake-On-LAN待机或休眠模式中唤醒
			
Wake-On-LAN简称WOL,是一种电源管理功能:如果存在网络活动,则允许设备将操作系统从待机或休眠模式中唤醒.许多主板厂商支持IBM提出的网络唤醒标准.该标准允许网络管理员远程打开PC机电源,以 ...
 - Java虚拟机几个命令行参数说明
			
一.运行class文件 执行带main方法的class文件,Java虚拟机命令参数行为: java <CLASS文件名> 注意:CLASS文件名不要带文件后缀.class 例如: java ...
 - 怎样在万网加入Lync Online SRV记录
			
万网已经支持SRV记录解析了,可是有好几个朋友问我怎么加入SRV记录(假设域名提供商不支持,能够通过DNSPOD来实现),过程例如以下 1:绑定域名至Office 365 略,请查看我的视频或者博客中 ...
 - oracle看到用户的所有表名、表睐、字段名称、现场的目光、是空的、字段类型
			
--oracle看到用户的所有表名.表睐.字段名称.现场的目光.是空的.字段类型 select distinct TABLE_COLUMN.*, TABLE_NALLABLE.DATA_TYPE, T ...
 - Qt数据类型转换
			
把QString转换为double类型 方法1.QString str="123.45"; double val=str.toDouble(); //val=123.45 方法2. ...