Hotel booking(spfa+floyd)
http://acm.hdu.edu.cn/showproblem.php?pid=2992
题意:有n个城市,编号为(1~n),有一些城市中有一些旅店,要求从一个城市到另一个城市不能超过10小时,问能否从1号城市到n号城市,如果能需要住的最少的旅店数目是多少。
思路:首先将1号城市和n号城市置为有旅店的城市,spfa求每个旅店到其它旅店的最短距离,如果距离小于10小时,将两个旅店之间的权值置为1,这样就能构造出所有旅店之间的图,然后对该图利用floyd求最短路。
- #include <stdio.h>
- #include <string.h>
- #include <algorithm>
- #include <queue>
- #include <vector>
- const int N=;
- const int INF=<<;
- using namespace std;
- struct node
- {
- int v,w;
- node(int v,int w):v(v),w(w) {}
- };
- vector<node>vv[N];
- int mp[][],id[N];
- int a[N],dis[N];
- bool vis[N];
- int hotel,n;
- void init()
- {
- memset(id,,sizeof(id));
- for (int i = ; i <= hotel+; i++)
- {
- for (int j = ; j <= hotel+; j++)
- {
- mp[i][j] = INF;
- }
- mp[i][i] = ;
- }
- for (int i = ; i <= n; i++)
- vv[i].clear();
- }
- void spfa(int s)
- {
- queue<int>q;
- memset(vis,,sizeof(vis));
- for (int i = ; i <= n; i++)
- dis[i] = INF;
- dis[s] = ;
- q.push(s);
- vis[s] = true;
- while(!q.empty())
- {
- int u = q.front();
- q.pop();
- vis[u] = false;
- for (int i = ; i < (int)vv[u].size(); i++)
- {
- int v = vv[u][i].v;
- int w = vv[u][i].w;
- if(dis[v]>dis[u]+w)
- {
- dis[v] = dis[u]+w;
- if(!vis[v])
- {
- q.push(v);
- vis[v] = true;
- }
- }
- }
- }
- for (int i = ; i <= n; i++)
- {
- if (dis[i]<=)
- mp[id[s]][id[i]] = ;
- }
- }
- void floyd()
- {
- for (int k = ; k <= hotel+; k++)
- {
- for (int i = ; i <= hotel+; i++)
- {
- for (int j = ; j <= hotel+; j++)
- if(mp[i][j] > mp[i][k]+mp[k][j])
- mp[i][j] = mp[i][k]+mp[k][j];
- }
- }
- }
- int main()
- {
- while(scanf("%d",&n)&&n)
- {
- scanf("%d",&hotel);
- init();
- for (int i = ; i <= hotel; i++)
- {
- scanf("%d",&a[i]);
- id[a[i]] = i;
- }
- a[] = ;
- a[hotel+] = n;
- id[] = ;
- id[n] = hotel+;
- int m,u,v,w;
- scanf("%d",&m);
- for (int i = ; i <= m; i++)
- {
- scanf("%d%d%d",&u,&v,&w);
- vv[u].push_back(node(v,w));
- vv[v].push_back(node(u,w));
- }
- for (int i = ; i <= hotel; i++)
- spfa(a[i]);
- floyd();
- if (mp[][hotel+]>=INF)
- puts("-1");
- else
- printf("%d\n",mp[][hotel+]-);
- }
- return ;
- }
Hotel booking(spfa+floyd)的更多相关文章
- HDU 2992 Hotel booking(BFS+DFS 或者 SPFA+Floyd)
点我看题目 题意 : 一个司机要从1点到达n点,1点到n点中有一些点有宾馆,司机的最长开车时间不能超过10小时,所以要在10小时之内找到宾馆休息,但是为了尽快的走到n点,问最少可以经过几个宾馆. 思路 ...
- PKU 1932 XYZZY(Floyd+Bellman||Spfa+Floyd)
题目大意:原题链接 给你一张图,初始你在房间1,初始生命值为100,进入每个房间会加上那个房间的生命(可能为负),问是否能到达房间n.(要求进入每个房间后生命值都大于0) 解题思路: 解法一:Floy ...
- 最短路算法详解(Dijkstra/SPFA/Floyd)
新的整理版本版的地址见我新博客 http://www.hrwhisper.me/?p=1952 一.Dijkstra Dijkstra单源最短路算法,即计算从起点出发到每个点的最短路.所以Dijkst ...
- hdu 1874 畅通工程续(模板题 spfa floyd)
题目:http://acm.hdu.edu.cn/showproblem.php?pid=1874 spfa 模板 #include<iostream> #include<stdio ...
- POJ 1502 MPI Maelstrom( Spfa, Floyd, Dijkstra)
题目大意: 给你 1到n , n个计算机进行数据传输, 问从1为起点传输到所有点的最短时间是多少, 其实就是算 1 到所有点的时间中最长的那个点. 然后是数据 给你一个n 代表有n个点, 然后给你一 ...
- hdu 2992 Hotel booking
http://acm.hdu.edu.cn/showproblem.php?pid=2992 #include <cstdio> #include <cstring> #inc ...
- 几个小模板:topology, dijkstra, spfa, floyd, kruskal, prim
1.topology: #include <fstream> #include <iostream> #include <algorithm> #include & ...
- 四大算法解决最短路径问题(Dijkstra+Bellman-ford+SPFA+Floyd)
什么是最短路径问题? 简单来讲,就是用于计算一个节点到其他所有节点的最短路径. 单源最短路算法:已知起点,求到达其他点的最短路径. 常用算法:Dijkstra算法.Bellman-ford算法.SPF ...
- POJ 1932 XYZZY (ZOJ 1935)SPFA+floyd
http://poj.org/problem?id=1932 http://acm.zju.edu.cn/onlinejudge/showProblem.do?problemCode=1935 题目大 ...
随机推荐
- linux vim 常用操作
vim 字符级 上k下j左h右i,键盘的方向键也可以移动 单词级 b上个单词首字母 w下个单词首字母 e下个单词的尾字母 行级 0行首 $行尾 删除 dd 删除光标所在行 文档级 gg 文档首行,首个 ...
- 利用gsoap库封装易用的rest框架
c++缺少web开发的框架,web框架分为异步和同步,异步的业务逻辑控制需要较强功底,同步代码实现起来容易,利于阅读理解 1.gsoap是c++写的webservice库,webservice应用层也 ...
- Django-REST-Framework JWT 实现SSO认证(上)
一.什么是Django-REST-Framework? Django-REST-framework 是基于Django框架的一个web RESTful风格开发的框架,它可以实现API接口的快速开发,但 ...
- python3虚拟环境应用
python3自带虚拟环境venv,大致操作只有三步 1. 创建虚拟环境 python3 -m venv venv(名称随意) 2. 激活虚拟环境 source venv/bin/activate 3 ...
- [linux]centos7下解决yum install mysql-server没有可用包
第一步:安装从网上下载文件的wget命令 [root@master ~]# yum -y install wget 第二步:下载mysql的repo源 [root@master ~]# wget ht ...
- codevs1197 Vigenère密码
题目描述 Description 16 世纪法国外交家Blaise de Vigenère设计了一种多表密码加密算法——Vigenère密码.Vigenère 密码的加密解密算法简单易用,且破译难度比 ...
- DJANGO中如何用邮箱来登陆?
就是另一个不同的登陆backend. 而DJANGO会尝不同的方式,哪个成功就用哪个 authentication.py from django.contrib.auth.models import ...
- [poj1678]I Love this Game!_博弈论
I Love this Game! 题目大意:题目链接 注释:略. 想法: 开始的时候以为没法dp,结果...:a>0啊! 所以可以直接dp了啊! 状态:dp[i]表示先手选了a[i]的状态. ...
- springmvc 日期转换器
package com.xxx.common.controller.converter; import org.joda.time.DateTime; import org.joda.time.for ...
- centos 7: 迁移MySQL目录
Steps: 1. systemctl stop mariadb 2. mkdir data destination folder, ex: /home/mysql 3. cp -R /var/lib ...