题意:每个城市举办庆祝有一定的花费,A在路径上会选择庆祝花费最大的城市

   让你求,A回家所花的路费和庆祝费最少,也就是说并不是最短路径就是结果,

   还有可能就是路费比最短路径的多,但是庆祝费就比它的少,总的加起来可能更小。

思路:枚举每个城市作为庆祝的点,设为x。以x为源点,用dijks求单源路径,路径上如果有大于x庆祝费的点,则不考虑进去。

    求完所有点到x的单源路径后,用两重j、k的for循环,同步更新从j到k所需要的最小花费

#include <iostream>
#include <algorithm>
#include <string.h>
#include <string>
#include <cstring>
#include <stdio.h>
#include <map>
#include <vector>
using namespace std;
const int maxn=0x3f3f3f3f; int c,r,q;
int c1,c2,d;
int a,b;
int road[][];
int feast[];
int ans[][];//ans[i][j]即为询问的答案,表示i到j最少的花费
int dis[];//当x为庆祝点时,dis[i]表示以第x城市作为举办宴会的地方,i到x之间的最短路径(即花费);
vector<int> link[];
int vis[];
int cases=;
int blank=; void init(){
for(int i=;i<=c;i++)
link[i].clear();
memset(road,maxn,sizeof(road));
memset(ans,maxn,sizeof(ans));
}
int main()
{
while(scanf("%d%d%d",&c,&r,&q)!=EOF){
if(c== && r== && q==)
break;
//如果不这样,则最后一个case输出完后会多打一个空格,这也给我wrong answer。。。
if(blank)
puts("");
else
blank=;
cases++;
init();
for(int i=;i<=c;i++){
scanf("%d",&feast[i]);
}
for(int i=;i<r;i++){
scanf("%d%d%d",&c1,&c2,&d);
road[c1][c2]=d;
road[c2][c1]=d;
link[c1].push_back(c2);
link[c2].push_back(c1);
} for(int i=;i<=c;i++){ //以i作为庆祝城市,并且以i作为源点,求单源路径
memset(dis,maxn,sizeof(dis));
dis[i]=;
memset(vis,,sizeof(vis)); //循环n次,这里我没用优先级队列
for(int z=;z<=c;z++){
int mincost=maxn;
int idx;
for(int k=;k<=c;k++){
if(vis[k]==){
if(dis[k]<mincost && feast[k]<=feast[i]){
mincost=dis[k];
idx=k;
}
}
}
vis[idx]=;
for(int g=;g<link[idx].size();g++){
int v=link[idx][g];
if(v!=idx){
if(feast[v]<=feast[i] && dis[idx]+road[idx][v]<dis[v]){
dis[v]=dis[idx]+road[idx][v];
}
}
}
} //每次求完以i为庆祝点的单源路径后,与之前比较,更新ans[j][k]的值,
//如果此次,从j到k之间在i点庆祝的花费比之前一次循环中的在i'庆祝的花费要少,则更新
for(int j=;j<=c;j++){
for(int k=;k<=c;k++){
if(feast[i]+dis[j]+dis[k]<ans[j][k]){
ans[j][k]=feast[i]+dis[j]+dis[k];
}
}
} }
printf("Case #%d\n",cases);
for(int i=;i<=q;i++){
scanf("%d%d",&a,&b);
if(ans[a][b]==maxn){
printf("-1\n");
}
else{
printf("%d\n",ans[a][b]);
}
}
//printf("\n"); }
return ;
}

UVA 10246 Asterix and Obelix的更多相关文章

  1. Asterix and Obelix

    uva10246:http://uva.onlinejudge.org/index.php?option=com_onlinejudge&Itemid=8&category=24&am ...

  2. uva 10246(最短路变形)

    题目链接:http://acm.hust.edu.cn/vjudge/problem/viewProblem.action?id=28972 思路:spfa求出每个点到其余顶点的最短路(最短路上的每个 ...

  3. UVA 10256 The Great Divide(凸包划分)

    The Great Divide Input: standard input Output: standard output Time Limit: 8 seconds Memory Limit: 3 ...

  4. KMP CF126B Password

    Description Asterix,Obelix和他们的临时伙伴Suffix.Prefix已经最终找到了和谐寺.然而和谐寺大门紧闭,就连Obelix的运气也没好到能打开它. 不久他们发现了一个字符 ...

  5. uva 1354 Mobile Computing ——yhx

    aaarticlea/png;base64,iVBORw0KGgoAAAANSUhEUgAABGcAAANuCAYAAAC7f2QuAAAgAElEQVR4nOy9XUhjWbo3vu72RRgkF5

  6. UVA 10564 Paths through the Hourglass[DP 打印]

    UVA - 10564 Paths through the Hourglass 题意: 要求从第一层走到最下面一层,只能往左下或右下走 问有多少条路径之和刚好等于S? 如果有的话,输出字典序最小的路径 ...

  7. UVA 11404 Palindromic Subsequence[DP LCS 打印]

    UVA - 11404 Palindromic Subsequence 题意:一个字符串,删去0个或多个字符,输出字典序最小且最长的回文字符串 不要求路径区间DP都可以做 然而要字典序最小 倒过来求L ...

  8. UVA&&POJ离散概率与数学期望入门练习[4]

    POJ3869 Headshot 题意:给出左轮手枪的子弹序列,打了一枪没子弹,要使下一枪也没子弹概率最大应该rotate还是shoot 条件概率,|00|/(|00|+|01|)和|0|/n谁大的问 ...

  9. UVA计数方法练习[3]

    UVA - 11538 Chess Queen 题意:n*m放置两个互相攻击的后的方案数 分开讨论行 列 两条对角线 一个求和式 可以化简后计算 // // main.cpp // uva11538 ...

随机推荐

  1. [GeekBand] C++ 高级编程技术 (1)

    一.类型转换 class Fraction { public: explicit Fraction(int num, int den=1) : m_numerator(num), m_denomina ...

  2. [转]高并发访问下避免对象缓存失效引发Dogpile效应

    避免Redis/Memcached缓存失效引发Dogpile效应 Redis/Memcached高并发访问下的缓存失效时可能产生Dogpile效应(Cache Stampede效应). 推荐阅读:高并 ...

  3. JQuery之proxy实现绑定代理

    在javascript中,this指代的对象时常会变化,这会造成程序,混乱,一般做法就是先将this保存在一个变量中,就不怕她变了,我们先看一个小例子 var A = function(){ this ...

  4. linux 关机方式

    linux 关机命令: 1-  init 0 关机. 具体详情接受可以 init --help 查询 如下: init [OPTIONS...] {COMMAND} Send control comm ...

  5. 【Qt】Qt之密码框不可选中、复制、粘贴、无右键菜单等【转】

    简述 在做用户登录.修改密码的时候,往往会用到密码框,其中一些功能要求与普通的输入框不同,例如:不能选中.复制.粘贴.无右键菜单等功能,当然设置密码不可见是必须的! 下面介绍两种方式来实现相同的效果. ...

  6. CenterOS中安装Redis及开机启动设置

    Redis安装 从官方下载最新Redis进行安装,官网地址:http://redis.io/download $ wget http://download.redis.io/releases/redi ...

  7. 免费GIT托管

    http://www.gitcentral.com http://www.projectlocker.com http://gitfarm.appspot.com http://code.google ...

  8. JS判断鼠标从什么方向进入一个容器

    偶然将想到的一个如何判断鼠标从哪个方向进入一个容器的问题.首先想到的是给容器的四个边添加几个块,然后看鼠标进入的时候哪个块先监听到鼠标事件.不过这样麻烦太多了.google了一下找到了一个不错的解决方 ...

  9. Microsoft Azure Powershell 获取Azure-Location

    首先要切换至AzureResourceManager模式下 http://www.cnblogs.com/SignalTips/p/4110790.html 国际版Get-AzureLocation ...

  10. Allegro中板子边框不封闭导致的z-copy无法用的问题

    画一个不规则的边框,有半圆形状,导致边框不封闭,无法使用Z-COPY命令,下边是解决办法: 1 画好Outline后,选择 shape -> Compose Shape , options选项卡 ...