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 ...
随机推荐
- node.js操作mongoDB数据库
链接数据库: var mongo=require("mongodb"); var host="localhost"; var port=mongo.Connec ...
- php中引用符号(&)的使用详解
php的引用就是在变量或者函数.对象等前面加上&符号,在PHP 中引用的意思是:不同的名字访问同一个变量内容,下面介绍如何使用PHP的引用 与C语言中的指针是有差别的.C语言中的指针里面存储的 ...
- 常见排序算法(PHP实现)
function InsertSort($arr){ $num = count($arr); for($i = 1; $i < $num; $i++){ $key = $arr[$i]; for ...
- Activity的跳转与传值(转载)
Activity跳转与传值,主要是通过Intent类来连接多个Activity,以及传递数据. Intent是Android一个很重要的类.Intent直译是“意图”,什么是意图呢?比如你想从这个 ...
- __attribute__ 详解
GNU C的一大特色(却不被初学者所知)就是__attribute__机制.__attribute__可以设置函数属性(Function Attribute).变量属性(Variable Att ...
- bootstrap框架应用
---------------------------------------------------------------bootstrap---------------------------- ...
- 解决在HTTPS页面里嵌套HTTP页面浏览器block的问题
问题描述: 浏览器默认是不允许在HTTPS里面引用HTTP页面的,ie下面会弹出提示框提示是否显示不安全的内容,一般都会弹出提示框,用户确认后才会继续加载,但是chrome下面直接被block掉,只在 ...
- csu 10月 月赛 H 题 A Very Hard Problem
Description CX老湿经常被人黑,被黑得多了,自己也就麻木了.于是经常听到有人黑他,他都会深情地说一句:禽兽啊! 一天CX老湿突发奇想,给大家出了一个难题,并且声称谁能够准确地回答出问题才能 ...
- 移动应用产品开发-android开发(三)
历时一个多月的时间,这款APP算是开发完成了,最近在测试完善中,比较空闲好好总结下. 之前两次已经提到开发过程中的主要的知识点,这次主要总结下解决问题方法,http请求和安全. 首先讲下解决问题的方法 ...
- Android adb使用sqlite3对一个数据库进行sql查询
sqlite是Android下集成的一个轻量级数据库,我们可以通过adb程序进入数据库命令行,对数据进行查询,具体操作如下: ①打开windows的cmd ②输入adb shell.此时进入了该安卓系 ...