洛谷 P1027 Car的旅行路线 最短路+Dijkstra算法
题面
题目链接
题目描述
又到暑假了,住在城市A的Car想和朋友一起去城市B旅游。她知道每个城市都有4个飞机场,分别位于一个矩形的4个顶点上,同一个城市中2个机场之间有1条笔直的高速铁路,第 $ i $ 个城市中高速铁路了的单位里程价格为 $ T_i $ ,任意两个不同城市的机场之间均有航线,所有航线单位里程的价格均为 $ t $

注意:图中并没有标出所有的铁路与航线。
那么Car应如何安排到城市B的路线才能尽可能的节省花费呢?她发现这并不是一个简单的问题,于是她来向你请教。
找出一条从城市A到B的旅游路线,出发和到达城市中的机场可以任意选取,要求总的花费最少。
输入输出格式
输入格式
第一行为一个正整数 $ n (0 \leq n \leq 10) $ ,表示有 $ n $ 组测试数据。
每组的第一行有4个正整数 $ s,t,A,B $
$ s (0<S \leq 100) $ 表示城市的个数, $ t $ 表示飞机单位里程的价格,A,B分别为城市A,B的序号,($ 1 \leq A,B \leq s $)。
接下来有 $ s $ 行,其中第 $ i $ 行均有7个正整数 $ xi_1,yi_1,xi_2,yi_2,xi_3,yi_3,Ti $ 这当中的 $ (xi_1,yi_1),(xi_2,yi_2),(xi_3,yi_3) $ 分别是第 $ i $ 个城市中任意3个机场的坐标, $ T_i $ 为第 $ i $ 个城市高速铁路单位里程的价格。
输出格式
共有 $ n $ 行,每行1个数据对应测试数据。 保留一位小数。
输入输出样例
输入样例
1
3 10 1 3
1 1 1 3 3 1 30
2 5 7 4 5 2 1
8 6 8 8 11 6 3
输出样例
47.5
说明
【时空限制】
1000ms,128MB
思路
首先看题,应该是个最短路题。只要把所有飞机场之间建边就可以了。但,还要处理这样一些问题
1.第四个点的位置。题中给了三个点的位置,那么就可以算出三边的长度,其中最长的那一条边一定是对角线,这样就可以计算第四个顶点的坐标了
2.建边的长度。如果两个飞机场是一个城市的,那么边的长度(费用)是这个城市高铁费用乘上实际长度;否则是飞机费乘实际长度
3.这道题可以从A的任意机场出发,到任意一个B的机场就终止。那么怎么变成单源最短路径呢?那么实际上可以将初始城市的四个点变成一个,也就是将他们之间的长度都变成0,再跑最短路就可以了
AC代码
#include<bits/stdc++.h>
const int maxn=105;
using namespace std;
int s,t,a,b;
struct City
{
int x[4],y[4];
int T;
}C[maxn];
int tot,to[maxn*maxn],nxt[maxn*maxn],head[maxn];
double d[maxn*maxn],ans[maxn*4];
bool vis[maxn*4];
priority_queue< pair<double,int> > q;
void Get0(int p)
{
City &q=C[p];
double l1=sqrt(((q.x[1])-(q.x[2]))*((q.x[1])-(q.x[2]))+((q.y[1])-(q.y[2]))*((q.y[1])-(q.y[2])));
double l2=sqrt(((q.x[1])-(q.x[3]))*((q.x[1])-(q.x[3]))+((q.y[1])-(q.y[3]))*((q.y[1])-(q.y[3])));
double l3=sqrt(((q.x[2])-(q.x[3]))*((q.x[2])-(q.x[3]))+((q.y[2])-(q.y[3]))*((q.y[2])-(q.y[3])));
double maxl=max(l1,max(l2,l3));
if(maxl==l1) q.x[0]=q.x[1]+q.x[2]-q.x[3],q.y[0]=q.y[1]+q.y[2]-q.y[3];
if(maxl==l2) q.x[0]=q.x[1]+q.x[3]-q.x[2],q.y[0]=q.y[1]+q.y[3]-q.y[2];
if(maxl==l3) q.x[0]=q.x[2]+q.x[3]-q.x[1],q.y[0]=q.y[2]+q.y[3]-q.y[1];
}
void Add(int u,int v,double len)
{
to[++tot]=v;nxt[tot]=head[u];head[u]=tot;d[tot]=len;
to[++tot]=u;nxt[tot]=head[v];head[v]=tot;d[tot]=len;
}
void Dijkstra()
{
for(int i=0;i<4*s;i++) ans[i]=99999999;
ans[4*a]=0;ans[4*a+1]=0;ans[4*a+2]=0;ans[4*a+3]=0;
memset(vis,0,sizeof(vis));
q.push(make_pair(0,4*a));
q.push(make_pair(0,4*a+1));
q.push(make_pair(0,4*a+2));
q.push(make_pair(0,4*a+3));
while(!q.empty())
{
int u=q.top().second;q.pop();
if(vis[u]) continue;
vis[u]=true;
for(int i=head[u];i;i=nxt[i])
{
int v=to[i];
if(ans[u]+d[i]<ans[v])
{
ans[v]=ans[u]+d[i];
q.push(make_pair(-ans[v],v));
}
}
}
}
void work()
{
scanf("%d%d%d%d",&s,&t,&a,&b);--a,--b;
for(int i=0;i<s;i++)
{
City &q=C[i];
scanf("%d%d%d%d%d%d%d",&q.x[1],&q.y[1],&q.x[2],&q.y[2],&q.x[3],&q.y[3],&q.T);
}
for(int i=0;i<s;i++) Get0(i);
double len;
for(int i=0,no1,no2,air1,air2;i<4*s;i++)
{
for(int j=0;j<4*s;j++)
{
no1=i/4;no2=j/4;air1=i%4;air2=j%4;
len=sqrt((C[no1].x[air1]-C[no2].x[air2])*(C[no1].x[air1]-C[no2].x[air2])+(C[no1].y[air1]-C[no2].y[air2])*(C[no1].y[air1]-C[no2].y[air2]));
if(no1==no2 && no1==a) len*=0;
else if(no1==no2) len*=C[no1].T;
else len*=t;
Add(i,j,len);
}
}
Dijkstra();
printf("%.1f\n",min(ans[b*4],min(ans[b*4+1],min(ans[b*4+2],ans[b*4+3]))));
}
int main()
{
int n;
scanf("%d",&n);
for(int i=1;i<=n;i++) work();
return 0;
}
总结
第四个点的处理算是一个小问题,还有将起点城市的四个点变成一个
洛谷 P1027 Car的旅行路线 最短路+Dijkstra算法的更多相关文章
- 洛谷P1027 Car的旅行路线
洛谷P1027 Car的旅行路线 题目描述 又到暑假了,住在城市A的Car想和朋友一起去城市B旅游.她知道每个城市都有四个飞机场,分别位于一个矩形的四个顶点上,同一个城市中两个机场之间有一条笔直的高速 ...
- 洛谷 P1027 Car的旅行路线
P1027 Car的旅行路线 题目描述 又到暑假了,住在城市A的Car想和朋友一起去城市B旅游.她知道每个城市都有四个飞机场,分别位于一个矩形的四个顶点上,同一个城市中两个机场之间有一条笔直的高速铁路 ...
- [NOIP2001] 提高组 洛谷P1027 Car的旅行路线
题目描述 又到暑假了,住在城市A的Car想和朋友一起去城市B旅游.她知道每个城市都有四个飞机场,分别位于一个 矩形的四个顶点上,同一个城市中两个机场之间有一条笔直的高速铁路,第I个城市中高速铁路了的单 ...
- 洛谷——P1027 Car的旅行路线
https://www.luogu.org/problem/show?pid=1027#sub 题目描述 又到暑假了,住在城市A的Car想和朋友一起去城市B旅游.她知道每个城市都有四个飞机场,分别位于 ...
- 洛谷1027 Car的旅行路线
原题链接 将每个城市拆成四个点,即四个机场来看,那么这题就是求最短路. 不过建图有些麻烦,先要找出第四个机场的坐标. 设另外三个机场的坐标为\((x_1, y_1), (x_2, y_2), (x_3 ...
- DP【洛谷P2134】 百日旅行
[洛谷P2134] 百日旅行 题目背景 重要的不是去哪里,而是和你在一起.--小红 对小明和小红来说,2014年7月29日是一个美好的日子.这一天是他们相识100天的纪念日. (小明:小红,感谢你2场 ...
- AC日记——Car的旅行路线 洛谷 P1027
Car的旅行路线 思路: 这题不难,就是有点恶心: 而且,请认真读题目(就是题目卡死劳资): 来,上代码: #include <cmath> #include <cstdio> ...
- P1027 car的旅行路线
car的旅行路线 洛谷链接 这个题关键就是 如何把每个点表示出来,其实求出四个点的坐标后,只需要把这些点连接起来,用一遍folyed求出最短路径就好了. 代码: #include<cmath&g ...
- BZOJ1880或洛谷2149 [SDOI2009]Elaxia的路线
BZOJ原题链接 洛谷原题链接 显然最长公共路径是最短路上的一条链. 我们可以把最短路经过的边看成有向边,那么组成的图就是一张\(DAG\),这样题目要求的即是两张\(DAG\)重合部分中的最长链. ...
随机推荐
- 记一次server 2008 R2的按装过程
项目上一直在用的dell务器在去年年底突然出现系统过期,导致c盘的东西全部丢失.我们用激活工具激活,还是没能找回丢失的东西. 为了装这个系统,跟同事一起折腾了好些次,最后发现安装服务器的时候有个磁盘阵 ...
- CSS样式汇总(转载)
1.字体属性:(font) 大小 {font-size: x-large;}(特大) xx-small;(极小) 一般中文用不到,只要用数值就可以,单位:PX.PD 样式 {font-style: o ...
- JavaScript对象继承方式
一.对象冒充 其原理如下:构造函数使用 this 关键字给所有属性和方法赋值(即采用类声明的构造函数方式).因为构造函数只是一个函数,所以可使 Parent 构造函数 成为 Children 的方法, ...
- 2019.10.28 csp-s模拟测试91 反思总结
有一场没一场的233 T1: 胡乱分析一下题意,发现和为n的x个正整数,不同的数字种类不会超过√n个.假设这x个数字都不同,最多也就是(x+1)*x/2=n. 所以可以维护现有的size值以及对应的数 ...
- Power Strings POJ2406 KMP 求最小循环节
相比一般KMP,构建next数组需要多循环一次,因为next[j]代表前j-1个字符的最长相同前缀后缀,比如字符串为aab aab aab共9个字符,则next[10]等于前9个字符中最长相同前缀后缀 ...
- Redis源码解析:22sentinel(三)客观下线以及故障转移之选举领导节点
八:判断实例是否客观下线 当前哨兵一旦监测到某个主节点实例主观下线之后,就会向其他哨兵发送"is-master-down-by-addr"命令,询问其他哨兵是否也认为该主节点主观下 ...
- ES6学习笔记之解构赋值
1.数组的解构赋值 简单用法 { // 旧 let a=1,b=3; //新 let [a,b]=[1,3]; console.log(a,b);// 1 3 } 只要等号两边的模式相同,左边的变量就 ...
- float示例
<!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8&quo ...
- 2016中国人工智能企业TOP100, CBinsight2016年100家人工智能公司
2016中国人工智能企业TOP100 不论在学界还是业界,均有代表人物对人工智能表示了担忧,如史蒂芬·霍金和比尔·盖茨.尽管如此,国内外科技巨头都积极发力人工智能,一波波创业者也相继涌入.人工智能成为 ...
- geoserver与OpenLayers配置
geoserver与OpenLayers配置 目录 1 准备工作.... 4 1.1 需要用到的程序和资料... 4 2 地图格式转换方式(一 ...