题意:

给你一幅图,然后起点终点,然后有一个条件是可以使某条边的花费减半,求最短路的最小花费。

思路:

(来自大哥)

最短路的时候多一维,途中是否有花费减半的边;

然后转移,如果上一条有减半的,这一条一定只能转移到不能减半,上一条没有减半的,这一条可以减半也可以不减半。

具体处理就是一个二维的处理,网上说分层图,其实我感觉就是DP的思想,还有有一种从一张图跑到另一张图的feel。

后来wa了,就是挫在初始化,还有数据要LL,哎,艹!;

贴一发自己的挫code…

#include<cstdio>
#include<iostream>
#include<queue>
#include<string.h>
#include<string>
#include<map>
#include<algorithm>
using namespace std;
#define LL long long const int N=5e5+10; struct asd{
int to;
LL w;
int next;
};
asd q[N*4];
int head[N*4],tol;
int n,m; map<string,int>mp;
int tot; int Getpoint(string ss)
{
if(mp.find(ss)!=mp.end())
return mp[ss];
return mp[ss]=++tot;
} void init()
{
memset(head,-1,sizeof(head));
mp.clear();
tol=0;
tot=0;
} void add(int a,int b,int c)
{
q[tol].to=b;
q[tol].w=c;
q[tol].next=head[a];
head[a]=tol++;
} typedef pair<int,int> PP;
queue<PP>que; const int M=1e5+10;
const long long INF=1e15;
LL dis[N][2];
bool vis[N][2];
int num[N][2];
LL spfa(int s,int t)
{
while(!que.empty())
que.pop();
for(int i=1;i<=n;i++)
{
dis[i][0]=INF;
dis[i][1]=INF;
vis[i][0]=false;
vis[i][1]=false;
num[i][0]=0;
num[i][1]=0;
}
dis[s][0]=dis[s][1]=0;
num[s][0]=num[s][1]=1;
vis[s][0]=vis[s][1]=true;
que.push(make_pair(s,0));
que.push(make_pair(s,1));
while(!que.empty())
{
PP u=que.front();
que.pop();
vis[u.first][u.second]=0;
for(int v=head[u.first];v!=-1;v=q[v].next)
{
int i=q[v].to;
if(u.second==1)
{
if(dis[i][1]>dis[u.first][u.second]+q[v].w)
{
dis[i][1]=dis[u.first][u.second]+q[v].w;
if(!vis[i][1])
{
vis[i][1]=1;
num[i][1]++;
if(num[i][1]>=tot)
return -1;
que.push(make_pair(i,1));
}
}
}
else
{
if(dis[i][0]>dis[u.first][u.second]+q[v].w)
{
dis[i][0]=dis[u.first][u.second]+q[v].w;
if(!vis[i][0])
{
vis[i][0]=1;
num[i][0]++;
if(num[i][0]>=tot)
return -1;
que.push(make_pair(i,0));
}
}
if(dis[i][1]>dis[u.first][u.second]+q[v].w/2)
{
dis[i][1]=dis[u.first][u.second]+q[v].w/2;
if(!vis[i][1])
{
vis[i][1]=1;
num[i][1]++;
if(num[i][1]>=tot)
return -1;
que.push(make_pair(i,1));
}
}
}
}
}
if(dis[t][1]==INF)
return -1;
return dis[t][1];
} int main()
{
while(~scanf("%d%d",&n,&m))
{
string x,y;
int w;
init();
for(int i=0;i<m;i++)
{
cin>>x>>y>>w;
int xx=Getpoint(x);
int yy=Getpoint(y);
//printf("%d %d\n",xx,yy);
add(xx,yy,w);
}
cin>>x>>y;
if(mp.find(x)==mp.end()||mp.find(y)==mp.end())
{
puts("-1");
continue;
}
int s=Getpoint(x);
int t=Getpoint(y);
//printf("%d %d\n",s,t);
printf("%lld\n",spfa(s,t));
}
return 0;
}

HDU 3499【最短路】的更多相关文章

  1. ACM: HDU 2544 最短路-Dijkstra算法

    HDU 2544最短路 Time Limit:1000MS     Memory Limit:32768KB     64bit IO Format:%I64d & %I64u Descrip ...

  2. UESTC 30 &&HDU 2544最短路【Floyd求解裸题】

    最短路 Time Limit: 5000/1000 MS (Java/Others)    Memory Limit: 32768/32768 K (Java/Others)Total Submiss ...

  3. hdu 5521 最短路

    Meeting Time Limit: 12000/6000 MS (Java/Others)    Memory Limit: 262144/262144 K (Java/Others)Total ...

  4. HDU - 2544最短路 (dijkstra算法)

    HDU - 2544最短路 Description 在每年的校赛里,所有进入决赛的同学都会获得一件很漂亮的t-shirt.但是每当我们的工作人员把上百件的衣服从商店运回到赛场的时候,却是非常累的!所以 ...

  5. Flight HDU - 3499 (分层最短路)

    Recently, Shua Shua had a big quarrel with his GF. He is so upset that he decides to take a trip to ...

  6. HDU2112 HDU Today 最短路+字符串哈希

    HDU Today Time Limit: 15000/5000 MS (Java/Others)    Memory Limit: 32768/32768 K (Java/Others)Total ...

  7. hdu 2544 最短路

    题目连接 http://acm.hdu.edu.cn/showproblem.php?pid=2544 最短路 Description 在每年的校赛里,所有进入决赛的同学都会获得一件很漂亮的t-shi ...

  8. hdu 2544 最短路 Dijkstra

    题目链接:http://acm.hdu.edu.cn/showproblem.php?pid=2544 题目分析:比较简单的最短路算法应用.题目告知起点与终点的位置,以及各路口之间路径到达所需的时间, ...

  9. HDU - 2680 最短路 spfa 模板

    题目链接http://acm.hdu.edu.cn/showproblem.php?pid=2680 题目大意,就是一个人可以从多个起点开始出发,看到终点的最短路是多少..只有可以运用和hdu2066 ...

随机推荐

  1. 2016/07/07 apmserv5.2.6 Apache启动失败,请检查相关配置。MySQL5.1已启动。

    因为要用PHP做一个程序,在本机上配PHP环境,下了个APMServ5.26,安装很简单,不再多说,装好后,启动,提示错误,具体是:“Apache启动失败,请检查相关配置.√MySQL5.1已启动”, ...

  2. Python多线程模块

    引言 thread threading 1 Thread 11 下面使用threading模块实现与上面相同的功能 12 在创建新线程时还可以给Thread传递可调用类的对象这样使用类本身来保存信息 ...

  3. HDU4565 So Easy! —— 共轭构造、二阶递推数列、矩阵快速幂

    题目链接:https://vjudge.net/problem/HDU-4565 So Easy! Time Limit: 2000/1000 MS (Java/Others)    Memory L ...

  4. Appium——详解Appium server capabilities

      appium server capabilities来告诉appium,如何运行自动化测试,因此需要详细了解. 官方文档:http://appium.io/slate/en/master/?rub ...

  5. ping返回 dup

    大概原因如下: 目的主机不可达,也就是 跟主机不在一个网段,也没有路由跳转 一般是远端交换机或HUB流量超过负载,即堵塞 应该是你的网络中存在环路路由,也就是到达你ping的主机有一条以上的路由路径, ...

  6. python字典无序?有序?

    默认情况下Python的字典输出顺序是按照键的创建顺序. 字典的无序是指,不能人为重新排序.比如说你按键值1,2,3,4的顺序创建的字典,只能由解析器按创建顺序,还是1,2,3,4的输出.你无法控制它 ...

  7. jQuery comet

    下面程序是例用从数据端推送信息,原理是每隔10秒读取一下data.txt文件,看有木有新的数据输入,如果有,则alert文件内容. hmtl代码是 <!DOCTYPE html> < ...

  8. web.xml中classpath 解释

    经过我在对 web.xml 的配置测试: web.xml 中classpath 所指的路径是项目工程路径下的 classes 文件夹

  9. hdu-5749 Colmerauer(单调栈)

    题目链接: Colmerauer Time Limit: 10000/5000 MS (Java/Others)     Memory Limit: 131072/131072 K (Java/Oth ...

  10. 如何在Flask的构架中传递logger给子模块

    Logger的传递 作为一个新手,如何将主函数的logger传入子模块是一件棘手的事情.某些情况下可以直接将logger作为参数传入子模块的构造函数中,但倘若子模块与主模块存在相互依赖的关系则容易出现 ...