HDU 3499【最短路】
题意:
给你一幅图,然后起点终点,然后有一个条件是可以使某条边的花费减半,求最短路的最小花费。
思路:
(来自大哥)
最短路的时候多一维,途中是否有花费减半的边;
然后转移,如果上一条有减半的,这一条一定只能转移到不能减半,上一条没有减半的,这一条可以减半也可以不减半。
具体处理就是一个二维的处理,网上说分层图,其实我感觉就是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【最短路】的更多相关文章
- ACM: HDU 2544 最短路-Dijkstra算法
HDU 2544最短路 Time Limit:1000MS Memory Limit:32768KB 64bit IO Format:%I64d & %I64u Descrip ...
- UESTC 30 &&HDU 2544最短路【Floyd求解裸题】
最短路 Time Limit: 5000/1000 MS (Java/Others) Memory Limit: 32768/32768 K (Java/Others)Total Submiss ...
- hdu 5521 最短路
Meeting Time Limit: 12000/6000 MS (Java/Others) Memory Limit: 262144/262144 K (Java/Others)Total ...
- HDU - 2544最短路 (dijkstra算法)
HDU - 2544最短路 Description 在每年的校赛里,所有进入决赛的同学都会获得一件很漂亮的t-shirt.但是每当我们的工作人员把上百件的衣服从商店运回到赛场的时候,却是非常累的!所以 ...
- 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 ...
- HDU2112 HDU Today 最短路+字符串哈希
HDU Today Time Limit: 15000/5000 MS (Java/Others) Memory Limit: 32768/32768 K (Java/Others)Total ...
- hdu 2544 最短路
题目连接 http://acm.hdu.edu.cn/showproblem.php?pid=2544 最短路 Description 在每年的校赛里,所有进入决赛的同学都会获得一件很漂亮的t-shi ...
- hdu 2544 最短路 Dijkstra
题目链接:http://acm.hdu.edu.cn/showproblem.php?pid=2544 题目分析:比较简单的最短路算法应用.题目告知起点与终点的位置,以及各路口之间路径到达所需的时间, ...
- HDU - 2680 最短路 spfa 模板
题目链接http://acm.hdu.edu.cn/showproblem.php?pid=2680 题目大意,就是一个人可以从多个起点开始出发,看到终点的最短路是多少..只有可以运用和hdu2066 ...
随机推荐
- CIDR(无类域间路由)(转载)
来源:百度百科 CIDR(无类型域间选路,Classless Inter-Domain Routing)是一个在Internet上创建附加地址的方法,这些地址提供给服务提供商(ISP),再由ISP分配 ...
- EasyDarwin开源团队招募开发组成员
EasyDarwin开源流媒体服务器项目招募开发组成员,共同更新和维护EasyDarwin流媒体服务器,决策EasyDarwin后续开发方向: 加入要求: 1.对开源流媒体项目有浓厚兴趣: 2.有一定 ...
- linux系统上安装svn服务器 环境linux+nginx+svnserver
系统:Ubuntu 12.04 64位 lnmp环境 集成软件:PHP5.4.27.Nginx1.6.0.MySQL5.5.37 阿里云server svnserver有2种执行方式:独立server ...
- Java其实不支持垃圾回收
Java其实不支持垃圾回收.如果真的支持的话,大多数Java程序在运行的一开始就应该把程序本身删除,因为这些程序本身就是垃圾. // TODO: This is a 分割线. Please no ...
- jquery特效(5)—轮播图③(鼠标悬浮停止轮播)
今天很无聊,就接着写轮播图了,需要说明一下,这次的轮播图是在上次随笔中jquery特效(3)—轮播图①(手动点击轮播)和jquery特效(4)—轮播图②(定时自动轮播)的基础上写出来的,也就是本次随笔 ...
- UVA11551 Experienced Endeavour —— 矩阵快速幂
题目链接:https://vjudge.net/problem/UVA-11551 题意: 给定一列数,每个数对应一个变换,变换为原先数列一些位置相加起来的和,问r次变换后的序列是多少 题解: 构造矩 ...
- 近期测试BUG总结
前些日子上线了新版的app,在上线后发现了几个重大的bug,在此总结,在以后的测试工作中需要额外的关注. 需求流程bug 页面刷新bug 标签栏刷新bug 第一个bug出现的原因是产品需求与运营实际操 ...
- PHP执行外部命令【转】
PHP是完全支持外部命令的,但是出于安全考虑,一般很少使用. PHP提供共了3种方法调用外部命令: (1)调用执行外部命令函数(system(),exec(),passthru(),shell_exe ...
- python中字符串的内置方法
这里说的是字符串中的内置方法,毕竟字符串是最常用的操作对象. ['__add__', '__class__', '__contains__', '__delattr__', '__doc__', '_ ...
- SQL Server 2008将数据导出为脚本 [SQL Server]
之前我们要将一个表中的数据导出为脚本,那么只有在网上找一个导出数据的Script,然后运行就可以导出数据脚本了.现在在SQL Server 2008的Management Studio中增加了一个新特 ...