【wikioi】1041 Car的旅行路线
算法:最短路(数据弱,Floyd也能过)
惨痛的教训:此题我至少提交了20次,原因在于= =太草率和粗心了,看到那个多少组数据以为是城市的数量,导致数组开得小小的= =。(对不起,wikioi的评测机= =)。一直报运行错误。。我居然一直没查到是越界= =TAT
记住:一定要看清数据范围啊啊啊啊啊!!!!!
此题最恶心的是处理第四个节点,刚开始我不知道怎么算第四个点(本人蒟蒻),以为单纯的x4=x1+x2-x3就可以过。。。可是不行。后面是看了题解的,应该是直角边终点x1,y1和x2,y2。所以要判断哪个是直角边。
对于线段L1、L2,如果 (x1-x2) * (x3-x2) + (y1-y2) * (y3-y2) = 0,那么L1 ⊥ L2。
上惨痛的代码:
#include <iostream>
#include <algorithm>
#include <cstring>
#include <iomanip>
#include <cmath>
using namespace std;
const double oo = 10000000;
//城市的飞机场 (x-1)*4+1代表第x个城市开始的飞机场下标
#define CTOA(x) (((x-1)<<2)+1)
//距离
#define DISTANCE(x1,y1,x2,y2) ((double)sqrt((x1-x2)*(x1-x2)+(y1-y2)*(y1-y2)))
//此题我用FLOYD做的,因为数据太弱,过了
//每个飞机场为一个节点,答案就是A到B所有的路线最短路的最小值
struct city
{
int x[4], y[4];
}ct[105]; double node[4050][4050];
double T;
int s, t, A, B, N, i, j, k, l, temp, airport, tx[3], ty[3];
//至于计算第四个点,由数学知识我们可以知道,相互垂直的两条直线的斜率互为负倒数,所以我们只要每次计算AB、BC的斜率。
//如果不满足条件,那么将A、B、C的坐标分别赋值为B、C、A,这样不断迭代,直到AB、BC垂直,这样就能计算出第四个点的坐标。
//还要注意一个问题,如果AB或者BC与坐标轴垂直,需要单独讨论这种情况,因为被除数不能为零。
//(1) 首先判断直角的位置:
//因为从测试数据文件中读入的三个点的坐标是无序的,因此需判断直角的位置,然后在计算第四个点的坐标。
//对于线段L1、L2,如果(x1-x2)*(x3-x2)+(y1-y2)*(y3-y2)=0,那么L1 ⊥ L2。
//(2) 计算(x4,y4):
//由x4-x3=x1-x2得x4=x1-x2+x3,同样的y4=y1-y2+y3
void getfour(int c) //获取第四个城市
{
memcpy(tx, ct[c].x, sizeof(tx));
memcpy(ty, ct[c].y, sizeof(ty));
int tt;
while((tx[0]-tx[1])*(tx[2]-tx[1])+(ty[0]-ty[1])*(ty[2]-ty[1]))
{
tt = tx[0]; tx[0]=tx[1]; tx[1]=tx[2]; tx[2]=tt;
tt = ty[0]; ty[0]=ty[1]; ty[1]=ty[2]; ty[2]=tt;
}
ct[c].x[3] = tx[0]-tx[1]+tx[2];
ct[c].y[3] = ty[0]-ty[1]+ty[2];} int main()
{
cin >> N;
while(N--)
{
cin >> s >> t >> A >> B;
//注意A=B的情况,也就是出发的城市就是结束的城市,这是要直接输出‘0.0’;
if(A == B) {cout << "0.0\n";continue;}
//s<<2表示飞机场数量,即s*4
airport = s << 2;
for(i = 1; i <= airport; i++)
for(j = 1; j <= airport; j++)
node[i][j] = oo; //初始化 for(i = 1; i <= s; i++)
{
for(j = 0; j < 3; j++)
cin >> ct[i].x[j] >> ct[i].y[j];
cin >> T;
getfour(i);
//初始同一城市飞机场的花费
for(j = 0; j < 4; j++)
for(k = 0; k < 4; k++)
if(j != k)
node[CTOA(i)+j][CTOA(i)+k] = DISTANCE(ct[i].x[j], ct[i].y[j], ct[i].x[k], ct[i].y[k]) * T;
} //初始不同城市飞机场的花费
for(i = 1; i <= s; i++)
for(j = 1; j <= s; j++)
if(i != j)
for(k = 0; k < 4; k++)
for(l = 0; l < 4; l++)
node[CTOA(i)+k][CTOA(j)+l] = (DISTANCE(ct[i].x[k], ct[i].y[k], ct[j].x[l], ct[j].y[l]) * t); //Floyd
for(k = 1; k <= airport; k++)
for(i = 1; i <= airport; i++)
for(j = 1; j <= airport; j++)
node[i][j] = min(node[i][j], node[i][k]+node[k][j]); //A到B所有的路线最短路的最小值
double ans = oo;
for(i = 0; i < 4; i++)
for(j = 0; j < 4; j++)
ans = min(ans, node[CTOA(A)+i][CTOA(B)+j]);
cout << setiosflags(ios::fixed) << setprecision(1) << ans << endl;
}
return 0;
}
【wikioi】1041 Car的旅行路线的更多相关文章
- [NOIP2001提高组]CODEVS1014 Car的旅行路线(最短路)
最短路,这个不难想,但是要为它加边就有点麻烦..还好写完就过了(虽然WA了一次,因为我调试用的输出没删了..),不然实在是觉得挺难调的.. ------------------------------ ...
- NOIP2001 Car的旅行路线
题四 Car的旅行路线(30分) 问题描述 又到暑假了,住在城市A的Car想和朋友一起去城市B旅游.她知道每个城市都有四个飞机场,分别位于一个矩形的四个顶点上,同一个城市中两个机场之间有一条笔直的高速 ...
- 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 ...
- 洛谷P1027 Car的旅行路线
洛谷P1027 Car的旅行路线 题目描述 又到暑假了,住在城市A的Car想和朋友一起去城市B旅游.她知道每个城市都有四个飞机场,分别位于一个矩形的四个顶点上,同一个城市中两个机场之间有一条笔直的高速 ...
- 洛谷 P1027 Car的旅行路线
P1027 Car的旅行路线 题目描述 又到暑假了,住在城市A的Car想和朋友一起去城市B旅游.她知道每个城市都有四个飞机场,分别位于一个矩形的四个顶点上,同一个城市中两个机场之间有一条笔直的高速铁路 ...
- AC日记——Car的旅行路线 洛谷 P1027
Car的旅行路线 思路: 这题不难,就是有点恶心: 而且,请认真读题目(就是题目卡死劳资): 来,上代码: #include <cmath> #include <cstdio> ...
- P1027 car的旅行路线
car的旅行路线 洛谷链接 这个题关键就是 如何把每个点表示出来,其实求出四个点的坐标后,只需要把这些点连接起来,用一遍folyed求出最短路径就好了. 代码: #include<cmath&g ...
- 洛谷 P1027 Car的旅行路线 最短路+Dijkstra算法
目录 题面 题目链接 题目描述 输入输出格式 输入格式 输出格式 输入输出样例 输入样例 输出样例 说明 思路 AC代码 总结 题面 题目链接 P1027 Car的旅行路线 题目描述 又到暑假了,住在 ...
随机推荐
- Java代码实现excel数据导入到Oracle
1.首先需要两个jar包jxl.jar,ojdbc.jar(注意版本,版本不合适会报版本错误)2.代码: Java代码 import java.io.File; import java.io.Fi ...
- poj 3468:A Simple Problem with Integers(线段树,区间修改求和)
A Simple Problem with Integers Time Limit: 5000MS Memory Limit: 131072K Total Submissions: 58269 ...
- LSM-Tree (BigTable 的理论模型)(转)
Google的BigTable架构在分布式结构化存储方面大名鼎鼎,其中的MergeDump模型在读写之间找到了一个较好的平衡点,很好的解决了web scale数据的读写问题. MergeDump的理论 ...
- STUN和TURN技术浅析
转自:http://blog.csdn.net/yu_xiang/article/details/9227023 在现实Internet网络环境中,大多数计算机主机都位于防火墙或NAT之后,只有少部分 ...
- Android JNI开发生成.h头文件问题(转)
在JNI开发中,首先要将建立的anroid类编译成.h文件,编译用到命令javah,由于第一次用,以前对java的编译过程也不怎么了解,所以走了好多弯路,网络没有对这一步的详细介绍,这里讲一下: 通过 ...
- 虚拟机安卓APK
输入命令,可以直接把桌面上的程序直接拖过来. 注意第二条命令,有"-r".
- javascript 获取url参数值
function getvl(name) { var reg = new RegExp("(^|\\?|&)"+ name +"=([^&]*)(\\s| ...
- Unity2D 之 Sprite点击事件
以下方法纯属我YY,切勿当真!!! 给 Sprite添加点击事件步骤: 1. 创建一个 Sprite 2. 给Sprite添加一个 Box Collider 2D 3. 将如果脚本放到Sprite上: ...
- 对android录制的NV21视频数据进行旋转(90,180,270)与剪切
android默认的视频采集格式是NV21,(属于YUV420) 在onPreviewFrame中传进来的byte[] data即为NV21格式. 旋转算法 对NV21进行顺时针旋转90度,180度和 ...
- 廖雪峰js教程笔记10 浏览器对象
JavaScript可以获取浏览器提供的很多对象,并进行操作. window window对象不但充当全局作用域,而且表示浏览器窗口. window对象有innerWidth和innerHeight属 ...