hdoj 5137 How Many Maos Does the Guanxi Worth【最短路枚举+删边】
How Many Maos Does the Guanxi Worth
Time Limit: 2000/1000 MS (Java/Others) Memory Limit: 512000/512000 K (Java/Others)
Total Submission(s): 1027 Accepted Submission(s):
349
of means "relationship" or "contact". Guanxi can be based on friendship, but
also can be built on money. So Chinese often say "I don't have one mao (0.1 RMB)
guanxi with you." or "The guanxi between them is naked money guanxi." It is said
that the Chinese society is a guanxi society, so you can see guanxi plays a very
important role in many things.
Here is an example. In many cities in
China, the government prohibit the middle school entrance examinations in order
to relief studying burden of primary school students. Because there is no clear
and strict standard of entrance, someone may make their children enter good
middle schools through guanxis. Boss Liu wants to send his kid to a middle
school by guanxi this year. So he find out his guanxi net. Boss Liu's guanxi net
consists of N people including Boss Liu and the schoolmaster. In this net, two
persons who has a guanxi between them can help each other. Because Boss Liu is a
big money(In Chinese English, A "big money" means one who has a lot of money)
and has little friends, his guanxi net is a naked money guanxi net -- it means
that if there is a guanxi between A and B and A helps B, A must get paid.
Through his guanxi net, Boss Liu may ask A to help him, then A may ask B for
help, and then B may ask C for help ...... If the request finally reaches the
schoolmaster, Boss Liu's kid will be accepted by the middle school. Of course,
all helpers including the schoolmaster are paid by Boss Liu.
You hate
Boss Liu and you want to undermine Boss Liu's plan. All you can do is to
persuade ONE person in Boss Liu's guanxi net to reject any request. This person
can be any one, but can't be Boss Liu or the schoolmaster. If you can't make
Boss Liu fail, you want Boss Liu to spend as much money as possible. You should
figure out that after you have done your best, how much at least must Boss Liu
spend to get what he wants. Please note that if you do nothing, Boss Liu will
definitely succeed.
For each test
case:
The first line contains two integers N and M. N means that there
are N people in Boss Liu's guanxi net. They are numbered from 1 to N. Boss Liu
is No. 1 and the schoolmaster is No. N. M means that there are M guanxis in Boss
Liu's guanxi net. (3 <=N <= 30, 3 <= M <= 1000)
Then M lines
follow. Each line contains three integers A, B and C, meaning that there is a
guanxi between A and B, and if A asks B or B asks A for help, the helper will be
paid C RMB by Boss Liu.
The input ends with N = 0 and M = 0.
It's
guaranteed that Boss Liu's request can reach the schoolmaster if you do not try
to undermine his plan.
has to spend after you have done your best. If Boss Liu will fail to send his
kid to the middle school, print "Inf" instead.
#include<stdio.h>
#include<string.h>
#include<algorithm>
#include<queue>
#define MAX 1010
#define INF 0x3f3f3f
using namespace std;
int n,m;
int low[MAX],map[MAX][MAX];
int vis[MAX];
void init()
{
for(int i=1;i<=n;i++)
for(int j=1;j<=n;j++)
map[i][j]=i==j?0:INF;
}
void getmap()
{
int i,j;
int a,b,c;
while(m--)
{
scanf("%d%d%d",&a,&b,&c);
if(map[a][b]>c)
map[a][b]=map[b][a]=c;
}
}
int dijkstra()
{
int i,j,next,min;
memset(vis,0,sizeof(vis));
for(i=1;i<=n;i++)
low[i]=map[1][i];
vis[1]=1;
for(i=2;i<=n;i++)
{
min=INF;
next=1;
for(j=1;j<=n;j++)
{
if(!vis[j]&&min>low[j])
{
next=j;
min=low[j];
}
}
vis[next]=1;
for(j=1;j<=n;j++)
{
if(!vis[j]&&low[j]>low[next]+map[next][j])
low[j]=low[next]+map[next][j];
}
}
return low[n];
}
int used[MAX][MAX];//记录被删边的权值
void solve()
{
int i,j;
int ans=dijkstra();
bool flag=false;
for(i=2;i<=n-1;i++)
{
for(j=1;j<=n;j++)
{
used[i][j]=used[j][i]=map[i][j];//将要删的边的权值记录下来
map[i][j]=map[j][i]=INF;//删边
}
if(dijkstra()==INF)//删边之后1到n不连通
{
flag=true;
break;
}
ans=max(dijkstra(),ans);//如果删边后任然联通,取最长路
for(j=1;j<=n;j++)//将这条边恢复,删除下一条边
map[i][j]=map[j][i]=used[i][j];
}
if(flag)
printf("Inf\n");
else
printf("%d\n",ans);
}
int main()
{
while(scanf("%d%d",&n,&m),n|m)
{
init();
getmap();
solve();
}
return 0;
}
hdoj 5137 How Many Maos Does the Guanxi Worth【最短路枚举+删边】的更多相关文章
- hdu 5137 How Many Maos Does the Guanxi Worth 最短路 spfa
How Many Maos Does the Guanxi Worth Time Limit: 2000/1000 MS (Java/Others) Memory Limit: 512000/5 ...
- HDU 5137 How Many Maos Does the Guanxi Worth 最短路 dijkstra
How Many Maos Does the Guanxi Worth Time Limit: 2000/1000 MS (Java/Others) Memory Limit: 512000/5 ...
- HDU 5137 How Many Maos Does the Guanxi Worth
How Many Maos Does the Guanxi Worth Time Limit: 2000/1000 MS (Java/Others) Memory Limit: 512000/5120 ...
- (hdoj 5137 floyd)How Many Maos Does the Guanxi Worth
How Many Maos Does the Guanxi Worth Time Limit: 2000/1000 MS (Java/Others) Memory Limit: 512000/5 ...
- HDU5137 How Many Maos Does the Guanxi Worth(枚举+dijkstra)
How Many Maos Does the Guanxi Worth Time Limit: 2000/1000 MS (Java/Others) Memory Limit: 512000/5 ...
- How Many Maos Does the Guanxi Worth
How Many Maos Does the Guanxi Worth Time Limit: 2000/1000 MS (Java/Others) Memory Limit: 512000/5 ...
- 杭电5137How Many Maos Does the Guanxi Worth
How Many Maos Does the Guanxi Worth Time Limit: 2000/1000 MS (Java/Others) Memory Limit: 512000/5 ...
- ACM学习历程——HDU5137 How Many Maos Does the Guanxi Worth(14广州10题)(单源最短路)
Problem Description "Guanxi" is a very important word in Chinese. It kind of means &quo ...
- hdu5137 How Many Maos Does the Guanxi Worth(单源最短路径)
题目链接:pid=5137">点击打开链接 题目描写叙述:如今有一张关系网.网中有n个结点标号为1-n.有m个关系,每一个关系之间有一个权值.问从2-n-1中随意去掉一个结点之后,从1 ...
随机推荐
- c# winform textbox与combox让用户不能输入
textbox的ReadOnly属性设置为true combox的Enable属性设置为false 运行后效果如下 点击第一个和第二个,会把按钮text赋值给文本框和combox 并且用户不能输入
- php5.3 不支持 session_register() 此函数已启用的解决方法
php从5.2.x升级到5.3.2.出来问题了.有些原来能用的程序报错了,Deprecated: Function session_register() is deprecated php从5.2.x ...
- Laravel Repository 模式
Repository 模式 为了保持代码的整洁性和可读性,使用Repository Pattern 是非常有用的.事实上,我们也不必仅仅为了使用这个特别的设计模式去使用Laravel,然而在下面的场景 ...
- Mysql锁机制和事务控制
如何加锁 锁定表的语法: LOCK TABLES tbl_name [AS alias] {READ [LOCAL] | [LOW_PRIORITY] WRITE} [, tbl_n ...
- python 数据运算
算数运算:
- 分享一下 Eclipse 插件 PyDev 的安装
想趁暑假学习一下python,学好语言好的开发环境是基础.因为安装有eclipse,所以想安装PyDev插件作为python开发环境.本来以为是一件简单的事情,结果整整弄了一下午各种装不上,度娘上的几 ...
- microsoft office visio基本使用方法
以下是画流程图.程序内存分配等等框图用到的点滴使用方法,记录在这里以备偶尔只需. 1.画大括号“{}” 在Visio操作界面下,依次点击“文件(File)”—“形状(Shapes)”--“其他Visi ...
- POJ 3264 Balanced Lineup 简单RMQ
题目:http://poj.org/problem?id=3264 给定一段区间,求其中最大值与最小值的差. #include <stdio.h> #include <algorit ...
- Clang 与 LLVM
我们在iOS调试中经常会看到Clang这个,那么Clang到底是什么呢?我们来简单了解一下. Clang是一个C.C++.OC语言的轻量级编译器.源代码发布于BSD协议下.Clang是由C++编写,基 ...
- uva 1396 - Most Distant Point from the Sea
半平面的交,二分的方法: #include<cstdio> #include<algorithm> #include<cmath> #define eps 1e-6 ...