Car的旅行路线 luogu P1027 (Floyd玄学Bug有点毒瘤)
Car的旅行路线
问题描述
那么Car应如何安排到城市B的路线才能尽可能的节省花费呢?她发现这并不是一个简单的问题,于是她来向你请教。
找出一条从城市A到B的旅游路线,出发和到达城市中的机场可以任意选取,要求总的花费最少。
S表示城市的个数,t表示飞机单位里程的价格,A,B分别为城市A,B的序号,(1<=A,B<=S)。
接下来有S行,其中第I行均有7个正整数xi1,yi1,xi2,yi2,xi3,yi3,Ti,这当中的(xi1,yi1),(xi2,yi2),(xi3,yi3)分别是第I个城市中任意三个机场的坐标,Tl为第I个城市高速铁路单位里程的价格。
1 10 1 3
1 1 1 3 3 1 30
2 5 7 4 5 2 1
8 6 8 8 11 6 3

题目中让我们求出从城市A到城市B的最小花费。
不难看出,这是一道最短路的问题,将最小花费看作每条边的长度,用SPFA(Floyd)跑最短路即可。
然而,每个城市有4个机场,去每个机场的花费都不一样。因此,考虑将一个城市拆分成4个点,在存点的时候储存下城市编号(类似强联通编号),进行特判就好了。
如果是同一个城市的,边长以为铁路票价 * dis, 不同城市则为 plane * dis。
答案即为终点四个机场中最小的。
(勾股定理好评!)
#include <bits/stdc++.h>
using namespace std;
#define N 401
#define isdigit(c) ((c)>='0'&&(c)<='9')
#define min(a,b) ((a)>(b)?(b):(a))
/*比 STL 快?*/ inline int read(){
int x = , s = ;
char c = getchar();
while(!isdigit(c)){
if(c == '-') s = -;
c = getchar();
}
while(isdigit(c)){
x = (x << ) + (x << ) + (c ^ '');
c = getchar();
}
return x * s;
} struct node{//存每个机场的信息
int x, y;
int city, price;
} t[N << ];
double d[N << ];
int n, pla_pri, s, ht; inline int square(int x){
return x * x;
} inline int dis(int a, int b){//暂时先不开根号,使用起来方便一些
return square(t[a].x - t[b].x) + square(t[a].y - t[b].y); //编号机场的距离
} inline void get4(int n1,int n2,int n3){
int x4, y4;
int x1 = t[n1].x, y1 = t[n1].y, x2 = t[n2].x, y2 = t[n2].y, x3 = t[n3].x, y3 = t[n3].y;
int ab = dis(n1, n2);
int ac = dis(n1, n3);
int bc = dis(n2, n3);
if(ab == ac + bc) x4 = x1 + x2 - x3, y4 = y1 + y2 - y3;//勾股定理,求出第四个点
else if(ac == ab + bc) x4 = x1 + x3 - x2, y4 = y1 + y3 - y2;
else if(bc == ac + ab) x4 = x2 + x3 - x1, y4 = y2 + y3 - y1;
t[n3+].x = x4, t[n3+].y = y4;
/* printf("x1:%d y1: %d x2: %d y2: %d x3: %d y3: %d x4: %d y4: %d\n", x1,y1,x2,y2,x3,y3,x4,y4);
分段检查程序可以防止写完之后 Debug 两小时 */
return ;
} void init(){
int cac_city = ;
for(int i = ;i <= (n << ); i += ){
t[i].x = read(), t[i].y = read();
t[i+].x = read(), t[i+].y = read();
t[i+].x = read(), t[i+].y = read();
t[i].price = t[i+].price = t[i+].price = t[i+].price = read();//把价格记录下来
t[i].city = t[i+].city = t[i+].city = t[i+].city = ++cac_city;//城市记录下来
get4(i, i+, i+);//寻找第四个点
}
return ;
} queue <int> q;
bool vis[N << ]; void spfa(){
/*时刻不忘 n 是4倍!!不然玄学错误!!*/
for(int i = ;i <= (n << ); i++)
d[i] = 99999999.99;
for(int i = * (s - ) + ;i <= * (s - ) + ; i++){//都能作为起点,所以4个点全部推进去
vis[i] = ;
q.push(i);
d[i] = ;
}
while(!q.empty()){//SPFA
int now = q.front();q.pop();
vis[now] = ;
for(int i = ;i <= (n << ); i++){//反正全部有连边,直接 for 循环不香吗
if(i == now)continue;
double cost;
if(t[i].city == t[now].city){//如果在同一个城市
cost = t[i].price * (double)sqrt((double)dis(i, now));
}
else cost = pla_pri * (double)sqrt((double)dis(i, now));//连边的价值(距离)
if(d[i] > d[now] + cost){
d[i] = d[now] + cost;
if(!vis[i]){
vis[i] = ;
q.push(i);
}
}
}
}
return ;
} int main(){
// freopen("hh.txt", "r", stdin);
int T = read();
while(T--){
n = read(), pla_pri = read(), s = read(), ht = read();
if(s == ht){ //这里用SPFA可以不特判,但是如果用Floyd就要特判了 (初始化成了极大值)
puts("0.0");
continue;
}
init();
spfa();
double ans = ~0u >> ;
for(int i = * (ht - ) + ;i <= * (ht - ) + + ; i++)
ans = min(d[i], ans);//答案为终点四个机场里面最小的
printf("%.1lf\n", ans);
}
return ;
}
Car的旅行路线 luogu P1027 (Floyd玄学Bug有点毒瘤)的更多相关文章
- 洛谷P1027 Car的旅行路线
洛谷P1027 Car的旅行路线 题目描述 又到暑假了,住在城市A的Car想和朋友一起去城市B旅游.她知道每个城市都有四个飞机场,分别位于一个矩形的四个顶点上,同一个城市中两个机场之间有一条笔直的高速 ...
- 洛谷 P1027 Car的旅行路线
P1027 Car的旅行路线 题目描述 又到暑假了,住在城市A的Car想和朋友一起去城市B旅游.她知道每个城市都有四个飞机场,分别位于一个矩形的四个顶点上,同一个城市中两个机场之间有一条笔直的高速铁路 ...
- 洛谷 P1027 Car的旅行路线 最短路+Dijkstra算法
目录 题面 题目链接 题目描述 输入输出格式 输入格式 输出格式 输入输出样例 输入样例 输出样例 说明 思路 AC代码 总结 题面 题目链接 P1027 Car的旅行路线 题目描述 又到暑假了,住在 ...
- AC日记——Car的旅行路线 洛谷 P1027
Car的旅行路线 思路: 这题不难,就是有点恶心: 而且,请认真读题目(就是题目卡死劳资): 来,上代码: #include <cmath> #include <cstdio> ...
- P1027 car的旅行路线
car的旅行路线 洛谷链接 这个题关键就是 如何把每个点表示出来,其实求出四个点的坐标后,只需要把这些点连接起来,用一遍folyed求出最短路径就好了. 代码: #include<cmath&g ...
- NOIP2001 Car的旅行路线
题四 Car的旅行路线(30分) 问题描述 又到暑假了,住在城市A的Car想和朋友一起去城市B旅游.她知道每个城市都有四个飞机场,分别位于一个矩形的四个顶点上,同一个城市中两个机场之间有一条笔直的高速 ...
- [NOIP2001提高组]CODEVS1014 Car的旅行路线(最短路)
最短路,这个不难想,但是要为它加边就有点麻烦..还好写完就过了(虽然WA了一次,因为我调试用的输出没删了..),不然实在是觉得挺难调的.. ------------------------------ ...
- GDOI2015小Z的旅行路线
GDOI2015小Z的旅行路线 题意: \(n\)个点的无根树,边上有权值. \(q\)个询问\(s\)和\(s\),问从\(s\)出发,找一条最长路(不经过重复点),保证路径上所有边边权不超过\(x ...
- 【Foreign】旅行路线 [倍增]
旅行路线 Time Limit: 20 Sec Memory Limit: 256 MB Description Input Output 仅一行一个整数表示答案. Sample Input 3 2 ...
随机推荐
- MySQL升级-CentOS6.8
在腾讯云购买的服务器自带的MySQL是5.1版本的,相对于最新版的5.7差了很多特性,在平时的项目练习中使用到了MySQL也会遇到一些奇葩的错误,很有必要升级到至少5.5版本以上. 步骤: 1.备份数 ...
- 数据结构与算法:栈(Stack)的实现
栈在程序设计当中是一个十分常见的数据结构,它就相当于一个瓶子,可以往里面装入各种元素,最先装进这个瓶子里的元素,要把后装进这个瓶子里的全部元素拿出来完之后才能够把他给拿出来.假设这个瓶子在桌上平放,左 ...
- node能做的性能优化
开发中,我们就离不开性能优化,那么在使用node开发的时候,我们可以使用那些代码来优化性能呢 一.释放内存 当node运行检测到错误的时候,释放掉内存 http.get(str,(res)=>{ ...
- Mybatis使用ResultMap
解决字段名和属性名不一致的问题 - 新建数据库表的字段-这里就不贴上了 在下面链接有 https://www.cnblogs.com/rzkwz/p/12853899.html 设置实体类和数据库字段 ...
- 【Spark】不熟悉Spark-shell常用参数?这一张图就够了
- 一文搞懂HMM(隐马尔可夫模型)-转载
写在文前:原博文地址:https://www.cnblogs.com/skyme/p/4651331.html 什么是熵(Entropy) 简单来说,熵是表示物质系统状态的一种度量,用它老表征系统的无 ...
- Vue 做的项目在IE下面打开一片空白解决方法
ie浏览器打开报这个错并且页面空白: 原因:这是因为浏览器对于部分ES6语法识别不出来导致,所以我们要安装一个插件,把ES6语法转换成IE浏览器可以识别的语法. 解决方法: 需要安装 "ba ...
- 帝国cms 批量删除包含关键字的 内容
删除包含关键字的 内容delete from www_kaifatu_com_ecms_news where playurl like '%关键字%'
- python --设置Python3 设置为机器默认
echo alias python=python3 >> ~/.bashrc source ~/.bashrc 反之,如果仍然需要Python2.7 ,则改成2.7就行. update : ...
- 漫谈Huawei LiteOS五大内核模块
[摘要]Huawei LiteOS是华为面向IoT领域,构建的“统一物联网操作系统和中间件软件平台”,以轻量级(内核小于10k).低功耗(1节5号电池最多可以工作5年),快速启动,互联互通,安全等关键 ...