nyoj 82 迷宫寻宝(二)
http://acm.nyist.net/JudgeOnline/problem.php?pid=83
题目解法主要在于判断两线段是否相交,思路是穷举所有地图四周的点,其中每一个边界上的点和终点构成一个线段, 求出所有线段和墙相交的最少次数就是结果
#include<stdio.h>
struct point
{
double x, y;
};
struct line
{
point a, b;
};
double det(double x1, double y1, double x2, double y2)//计算叉积
{
return x1 * y2 - x2 * y1;
}
double get_dir(point a, point b, point c)//计算向量ac 在向量ab的哪个方向(正数为逆时针,负数为顺时针, 零为同向或者反向)
{
return det(b.x - a.x, b.y - a.y, c.x - a.x, c.y - a.y);
}
int check_cross(line a, line b)//计算出两条线段是否相交,注意只有确定两条线段的都在对方的两侧,才能确定这两条线段相交
{
double flag1 = get_dir(a.a, a.b, b.a) * get_dir(a.a, a.b, b.b);
int f1 = flag1 > 0 ? 1 : -1;
double flag2 = get_dir(b.a, b.b, a.a) * get_dir(b.a, b.b, a.b);
int f2 = flag2 > 0? 1 : -1;
if(f1 < 0 && f2 < 0)
return -1;
else
return 1;
}
line lines[40];
int axis1[101], axis2[101], axis3[101], axis4[101];
int get_cross_number(point start, point end, int total)//计算相交次数
{
line templine;
templine.a = start;
templine.b = end;
int count = 0;
int i;
for(i = 0; i < total; i++)
{
if(check_cross(templine, lines[i]) - 0 < 1e-6)
count ++;
}
return count;
}
int main()
{
int n;
scanf("%d", &n);
while(n--)
{ int m;
int top1, top2, top3, top4;
top1 = top2 = top3 = top4 = 0;
scanf("%d", &m);
int i;
for(i = 0; i < m; i++)
{
int x1, x2, y1, y2;
scanf("%d %d %d %d", &x1, &y1, &x2, &y2);
lines[i].a.x = x1;
lines[i].a.y = y1;
lines[i].b.x = x2;
lines[i].b.y = y2;
}
point end;
scanf("%lf %lf", &end.x, &end.y);
int min = 0x7fffffff;
for(i = 0; i < 101; i++)
{
if(min == 0)
break;
point start;
int res;
start.x = 0;
start.y = i;
res = get_cross_number(start, end, m);
if(res < min)
min = res;
start.x = 100;
start.y = i;
res = get_cross_number(start, end, m);
if(res < min)
min = res;
start.x = i;
start.y = 0;
res = get_cross_number(start, end, m);
if(res < min)
min = res;
start.x = i;
start.y = 100;
res = get_cross_number(start, end, m);
if(res < min)
min = res;
}
printf("%d\n", min + 1);
}
return 0;
}
nyoj 82 迷宫寻宝(二)的更多相关文章
- nyoj 82 迷宫寻宝(一)
点击打开链接 迷宫寻宝(一) 时间限制:1000 ms | 内存限制:65535 KB 难度:4 描述 一个叫ACM的寻宝者找到了一个藏宝图,它根据藏宝图找到了一个迷宫,这是一个很特别的迷宫,迷宫 ...
- nyoj 83:迷宫寻宝(二)(计算几何)
题目链接 枚举所有墙的2n个端点与宝物的位置作为一条线段(墙的端点必定与边界重合), 求出与之相交的最少线段数(判断线段相交时用跨立实验的方法),+1即为结果. #include<bits/st ...
- nyist 82迷宫寻宝(一)(BFS)
题目连接:http://acm.nyist.net/JudgeOnline/problem.php?pid=82 此题在基础BFS上加入了门和钥匙,要找齐所有钥匙才能开门,所以要对门特殊处理. 1.先 ...
- Unity3D实现立体迷宫寻宝
Unity3D实现立体迷宫寻宝 这个小游戏是一个白痴在一个昏暗的房间走动找到关键得分点,然后通关游戏.入门Unity3D做的第一款游戏,比较无聊,但实现了一般的游戏功能.如,人物控制,碰撞检测,主控制 ...
- 迷宫寻宝(一)(bfs)
迷宫寻宝(一) 时间限制:1000 ms | 内存限制:65535 KB 难度:4 描述 一个叫ACM的寻宝者找到了一个藏宝图,它根据藏宝图找到了一个迷宫,这是一个很特别的迷宫,迷宫里有N个编 ...
- Problem 2285 迷宫寻宝 (BFS)
题目链接:http://acm.fzu.edu.cn/problem.php?pid=2285 Problem 2285 迷宫寻宝 Accept: 323 Submit: 1247Time Li ...
- 福州大学第十五届程序设计竞赛_重现赛B题迷宫寻宝
Problem B 迷宫寻宝 Accept: 52 Submit: 183Time Limit: 1000 mSec Memory Limit : 32768 KB Problem De ...
- NYOJ82 迷宫寻宝(一)【BFS】
迷宫寻宝(一) 时间限制:1000 ms | 内存限制:65535 KB 难度:4 描写叙述 一个叫ACM的寻宝者找到了一个藏宝图.它依据藏宝图找到了一个迷宫,这是一个非常特别的迷宫,迷宫里有N个 ...
- nyoj 83-迷宫寻宝(二) (计算几何, 叉积)
83-迷宫寻宝(二) 内存限制:10MB 时间限制:1000ms 特判: No 通过数:2 提交数:6 难度:5 题目描述: 一个叫ACM的寻宝者找到了一个藏宝图,它根据藏宝图找到了一个迷宫,这是一个 ...
随机推荐
- 在博文中嵌入Javascript代码
今天吃饭时无聊,突然想到Markdown除了兼容HTML会不会也兼容Javascript,于是博文里除了码文插音乐还可以干点更好玩的事儿了,可以自动修改markdown文件本身,比如说自动修改从Git ...
- PARSEC-3.0编译错误
OS: Ubuntu 14.04 LTS (x86_64) ***error 1 OpenSSL 1.0.1e 与 perl5.18 不兼容 POD document had syntax error ...
- iOS开发~CocoaPods使用详细说明
一.概要 iOS开发时,项目中会引用许多第三方库,CocoaPods(https://github.com/CocoaPods/CocoaPods)可以用来方便的统一管理这些第三方库. 二.安装 由于 ...
- C#中ref,out
out 关键字会导致参数通过引用来传递.这与 ref 关键字类似,不同之处在于 ref 要求变量必须在传递之前进行初始化.若要使用 out 参数,方法定义和调用方法都必须显式使用 out 关键字 比如 ...
- 自学 PHP,如何不走弯路?
1.一本好书至关重要.如果这本书的知识非常深入,那么还是不要看了.对初学者来说只能是打击.因为很多东西都看不懂.一本知识较为浅显,并且说明非常详细,但是能让你上手的基础知识又非常完善的书籍就非常好.( ...
- HDU-2296 Ring(AC自动机+DP)
题目大意:给出的m个字符串都有一个权值.用小写字母构造一个长度不超过n的字符串S,如果S包含子串s,则S获取s的权值.输出具有最大权值的最小字符串S. 题目分析:先建立AC自动机.定义状态dp(ste ...
- 1月11日,HTML学习笔记
<ul> <li>coffee</li> <li>tea</li> <li>mile</li> </ul> ...
- Extnet Direct 提交后台事件文件下载设置
App.direct.MasterData.Export(App.tfSearch.getValue(), { isUpload: true ...
- 闪回恢复区大小不够。报ORA-19809、ORA-19804
问题: 闪回恢复区大小不够,rman默认备份路径报错.RMAN> backup database;Starting backup at 01-DEC-14using target databas ...
- WebService 不依赖配置文件直接在构造函数配置地址
研究了下 ClientBase(Binding binding, EndpointAddress remoteAddress) 这个重载更好用,都不用填名称比如 new PAS.WebService. ...