意甲冠军:

到n节点无向图,它要求从一个线1至n路径。你可以让他们在k无条,的最大值。如今要求花费的最小值。

思路:

这道题能够首先想到二分枚举路径上的最大值,我认为用spfa更简洁一些。spfa的本质是一种搜索算法,既然是搜索,就涉及到状态的转移。

在一般求最短路的spfa算法中,当到结点u时,对e(u,v)仅仅需做例如以下转移:if(d[v]>d[u]+w(e)) d[v]=d[u]+w(e)。在跟一般的情况下。到结点u,对e(u,v)需做多种转移。比方这题中要考虑让e免费和不让e免费两种情况,详细的请參考实现。

代码:

//poj 3662
//sepNINE
#include <iostream>
#include <queue>
using namespace std;
const int maxN=1024;
const int maxM=10024; struct Edge
{
int v,w,next;
}edge[maxM*2]; struct Node
{
int u,used;
};
int n,p,k,e;
int head[maxN],dis[maxN][maxN],vis[maxN][maxN]; void spfa(int s,int t,int k)
{
queue<Node> Q;
memset(vis,0,sizeof(vis));
int i,j;
for(i=1;i<=n;++i)
for(j=0;j<=k;++j)
dis[i][j]=INT_MAX;
Node x;
x.u=s;
x.used=0;
dis[s][0]=0;
vis[s][0]=1;
Q.push(x);
while(!Q.empty()){
Node x=Q.front();
int u=x.u,used=x.used;
Q.pop();
vis[u][used]=0;
for(int i=head[u];i!=-1;i=edge[i].next){
int v=edge[i].v,w=edge[i].w;
if(used+1<=k&&dis[v][used+1]>dis[u][used]){//让这条边免费,免费的边数used要+1
dis[v][used+1]=dis[u][used];
if(vis[v][used+1]==0){
Node x;
x.u=v;x.used=used+1;
vis[x.u][x.used]=1;
Q.push(x);
}
}
if(dis[v][used]>max(dis[u][used],w)){//不让这条边免费。dis[v][used]为dis[u][used]和w中的最大值
dis[v][used]=max(dis[u][used],w);
if(vis[v][used]==0){
Node x;
x.u=v;x.used=used;
vis[x.u][x.used]=1;
Q.push(x);
}
}
} }
return ;
} int main()
{
scanf("%d%d%d",&n,&p,&k);
e=0;
memset(head,-1,sizeof(head));
while(p--){
int a,b,c;
scanf("%d%d%d",&a,&b,&c);
edge[e].v=b;edge[e].w=c,edge[e].next=head[a];head[a]=e++;
edge[e].v=a;edge[e].w=c;edge[e].next=head[b];head[b]=e++;
}
spfa(1,n,k);
int ans=INT_MAX;
for(int i=0;i<=k;++i)
ans=min(ans,dis[n][i]);
if(ans==INT_MAX)
printf("-1");
else
printf("%d",ans);
return 0;
}

poj 3662 Telephone Lines spfa算法灵活运用的更多相关文章

  1. (poj 3662) Telephone Lines 最短路+二分

    题目链接:http://poj.org/problem?id=3662 Telephone Lines Time Limit: 1000MS   Memory Limit: 65536K Total ...

  2. POJ 3662 Telephone Lines【Dijkstra最短路+二分求解】

    Telephone Lines Time Limit: 1000MS   Memory Limit: 65536K Total Submissions: 7214   Accepted: 2638 D ...

  3. poj 3662 Telephone Lines

    Telephone Lines Time Limit: 1000MS   Memory Limit: 65536K Total Submissions: 7115   Accepted: 2603 D ...

  4. POJ 3662 Telephone Lines (分层图)

    Telephone Lines Time Limit: 1000MS   Memory Limit: 65536K Total Submissions: 6785   Accepted: 2498 D ...

  5. poj 3662 Telephone Lines(最短路+二分)

    Telephone Lines Time Limit: 1000MS   Memory Limit: 65536K Total Submissions: 6973   Accepted: 2554 D ...

  6. poj 3662 Telephone Lines dijkstra+二分搜索

    Telephone Lines Time Limit: 1000MS   Memory Limit: 65536K Total Submissions: 5696   Accepted: 2071 D ...

  7. POJ 3662 Telephone Lines(二分答案+SPFA)

    [题目链接] http://poj.org/problem?id=3662 [题目大意] 给出点,给出两点之间连线的长度,有k次免费连线, 要求从起点连到终点,所用的费用为免费连线外的最长的长度. 求 ...

  8. poj 3662 Telephone Lines(好题!!!二分搜索+dijkstra)

    Description Farmer John wants to set up a telephone line at his farm. Unfortunately, the phone compa ...

  9. POJ 3662 Telephone Lines (二分 + 最短路)

    Farmer John wants to set up a telephone line at his farm. Unfortunately, the phone company is uncoop ...

随机推荐

  1. HTML5 Canvas动画效果实现原理

    在线演示 使用HTML5画布可以帮助我们高速实现简单的动画效果.基本原理例如以下: 每隔一定时间绘制图形而且清除图形,用来模拟出一个动画过程,能够使用context.clearRect(0, 0, x ...

  2. Ubuntu 12.04更新源

    源地址:http://www.cnblogs.com/eastson/archive/2012/08/24/2654163.html 1.首先备份Ubuntu12.04源列表 sudo cp /etc ...

  3. oschina 建站系统

    建站系统 分类网站程序(9) 众筹平台(2) 团购网站系统(14) 开源轻博客系统(8) 开源博客系统(279) 视频网站系统(9) 开源微博工具(93) 论坛系统BBS(129) 建站系统CMS(5 ...

  4. [置顶] ※数据结构※→☆线性表结构(stack)☆============栈 序列表结构(stack sequence)(六)

    栈(stack)在计算机科学中是限定仅在表尾进行插入或删除操作的线性表.栈是一种数据结构,它按照后进先出的原则存储数据,先进入的数据被压入栈底,最后的数据在栈顶,需要读数据的时候从栈顶开始弹出数据.栈 ...

  5. poj1860(spfa判正环)

    题目连接:http://poj.org/problem?id=1860 题意:有多种从a到b的汇率,在你汇钱的过程中还需要支付手续费,那么你所得的钱是 money=(nowmoney-手续费)*rat ...

  6. poj1797(最短路小变形)

    题目连接:http://poj.org/problem?id=1797 题意: 分析:dp[i]表示到达i点的过程中的最大承受重量,更新到i点时可能有多条路径,由优先队列堆出最大的那条即可. #inc ...

  7. linux LNMP自动安装脚本

    #!/bin/bashsoft_dir="/home/soft"config_dir="/home/config"httpd="httpd-2.0.5 ...

  8. Android Studio 入门(转)

    本文适用于从Eclipse转AndroidStudio的开发者 最近打算写一个系列的android初级开发教程,预计40篇以上的文章,结合我实际工作中的经验,写一些工作中经常用到的技术,让初学者可以少 ...

  9. PHP实现插入排序算法

    插入排序(Insertion Sort),是一种较稳定.简单直观的排序算法.插入排序的工作原理,是通过构建有序序列,对于未排序的数据,在有序序列中从后向前扫描,找到合适的位置并将其插入.插入排序,在最 ...

  10. 压缩js参数保存解决方法

    angular.js  中 找到 if (typeof fn === 'function') 在 if (fn.length) { console.warn("此函数没有注入注解,将导致编译 ...