poj1269 intersecting lines【计算几何】
Your program will repeatedly read in four points that define two lines in the x-y plane and determine how and where the lines intersect. All numbers required by this problem will be reasonable, say between -1000 and 1000.
Input
Output
Sample Input
5
0 0 4 4 0 4 4 0
5 0 7 6 1 0 2 3
5 0 7 6 3 -6 4 -3
2 0 2 27 1 5 18 5
0 3 4 0 1 2 2 5
Sample Output
INTERSECTING LINES OUTPUT
POINT 2.00 2.00
NONE
LINE
POINT 2.00 5.00
POINT 1.07 2.20
END OF OUTPUT
求交点的水题
列一下直线的解析式推一下公式就行了
需要注意的是如果用斜率式要注意斜率不存在的情况 啊我好菜我都不记得直线别的解析式要怎么搞了
嗯觉得我写题目的速度实在是太慢了 今天过来也没有要读题结果这种水题还写了这么久
#include <iostream>
#include<stdio.h>
#include<math.h>
#define inf 0x3f3f3f3f
using namespace std;
struct point{
double x, y;
};
struct line{
point st, ed;
double k, b;
};
double getk(line a)
{
point ed = a.ed, st = a.st;
if(ed.x == st.x)return inf;
double k = (ed.y - st.y)/ (ed.x - st.x);
return k;
}
double getb(line a)
{
point ed = a.ed, st = a.st;
if(ed.x == st.x)return -inf;
double b = st.y - st.x * a.k;
return b;
}
point inter(line a, line b)
{
point p1 = a.st, p2 = a.ed, p3 = b.st, p4 = b.ed;
point in;
in.x = (p2.x - p1.x) * (p4.x - p3.x) * (p3.y - p1.y) + (p4.x - p3.x) * (p2.y - p1.y) * p1.x - (p2.x - p1.x) * (p4.y - p3.y) * p3.x;
in.x = in.x / ((p4.x - p3.x) * (p2.y - p1.y) - (p2.x - p1.x) * (p4.y - p3.y));
in.y = a.k * in.x + a.b;
return in;
}
int n;
point a, b, c, d;
line l1, l2;
int main()
{
while(scanf("%d",&n) != EOF){
cout<<"INTERSECTING LINES OUTPUT\n";
for(int i = 0; i < n; i++){
cin>>a.x>>a.y>>b.x>>b.y>>c.x>>c.y>>d.x>>d.y;
l1.st = a;l1.ed = b;
l2.st = c;l2.ed = d;
l1.k = getk(l1);l1.b = getb(l1);
l2.k = getk(l2);l2.b = getb(l2);
if(l1.k == l2.k){
if(l1.k == inf){
if(l1.st.x == l2.st.x){
cout<<"LINE\n";
}
else{
cout<<"NONE\n";
}
}
else if(l1.b == l2.b){
cout<<"LINE\n";
}
else{
cout<<"NONE\n";
}
}
else if(l1.k == inf){
point ans;
ans.x = l1.st.x;
ans.y = l2.k * ans.x + l2.b;
printf("POINT %.2f %.2f\n", ans.x, ans.y);
}
else if(l2.k == inf){
point ans;
ans.x = l2.st.x;
ans.y = l1.k * ans.x + l1.b;
printf("POINT %.2f %.2f\n", ans.x, ans.y);
}
else{
point ans = inter(l1, l2);
printf("POINT %.2f %.2f\n", ans.x, ans.y);
}
}
cout<<"END OF OUTPUT\n";
}
return 0;
}
poj1269 intersecting lines【计算几何】的更多相关文章
- POJ P2318 TOYS与POJ P1269 Intersecting Lines——计算几何入门题两道
rt,计算几何入门: TOYS Calculate the number of toys that land in each bin of a partitioned toy box. Mom and ...
- POJ1269:Intersecting Lines(判断两条直线的关系)
题目:POJ1269 题意:给你两条直线的坐标,判断两条直线是否共线.平行.相交,若相交,求出交点. 思路:直线相交判断.如果相交求交点. 首先先判断是否共线,之后判断是否平行,如果都不是就直接求交点 ...
- POJ 1269 Intersecting Lines --计算几何
题意: 二维平面,给两条线段,判断形成的直线是否重合,或是相交于一点,或是不相交. 解法: 简单几何. 重合: 叉积为0,且一条线段的一个端点到另一条直线的距离为0 不相交: 不满足重合的情况下叉积为 ...
- POJ1269 Intersecting Lines[线段相交 交点]
Intersecting Lines Time Limit: 1000MS Memory Limit: 10000K Total Submissions: 15145 Accepted: 66 ...
- [poj1269]Intersecting Lines
题目大意:求两条直线的交点坐标. 解题关键:叉积的运用. 证明: 直线的一般方程为$F(x) = ax + by + c = 0$.既然我们已经知道直线的两个点,假设为$(x_0,y_0), (x_1 ...
- POJ1269 Intersecting Lines 2017-04-16 19:43 50人阅读 评论(0) 收藏
Intersecting Lines Time Limit: 1000MS Memory Limit: 10000K Total Submissions: 15478 Accepted: 67 ...
- POJ 1269 Intersecting Lines(计算几何)
题意:给定4个点的坐标,前2个点是一条线,后2个点是另一条线,求这两条线的关系,如果相交,就输出交点. 题解:先判断是否共线,我用的是叉积的性质,用了2遍就可以判断4个点是否共线了,在用斜率判断是否平 ...
- POJ1269:Intersecting Lines——题解
http://poj.org/problem?id=1269 题目大意:给四个点,求前两个点所构成的直线和后两个点所构成的直线的位置关系(平行,重合,相交),如果是相交,输出交点坐标. ——————— ...
- ●POJ 1269 Intersecting Lines
题链: http://poj.org/problem?id=1269 题解: 计算几何,直线交点 模板题,试了一下直线的向量参数方程求交点的方法. (方法详见<算法竞赛入门经典——训练指南> ...
随机推荐
- nuget类库xml说明以及类库说明文件添加到包中
1.nuget包制作添加xml操作:项目右键属性,生成配置输出xml文档文件,debug,release都配置一下,项目右键 yesway.redis.csproj 文件增加: 添加类库说明文件con ...
- struts2防止反复提交的办法
<? xml version="1.0" encoding="UTF-8" ?> <!DOCTYPE struts PUBLIC " ...
- MapWinGIS------引发类型为“System.Windows.Forms.AxHost+InvalidActiveXStateException”的异常
转载:http://www.cnblogs.com/dzone/archive/2011/09/08/2171445.html
- NYOJ 116 士兵杀敌 (线段树,区间和)
题目链接:NYOJ 116 士兵杀敌 士兵杀敌(二) 时间限制:1000 ms | 内存限制:65535 KB 难度:5 描写叙述 南将军手下有N个士兵,分别编号1到N,这些士兵的杀敌数都是已知的 ...
- 爬虫 测试webmagic (一)
目标:统计斗鱼(www.douyu.com)人数 思路: 1. 目录找到douyu播出的所有游戏 http://www.douyutv.com/directory 2. 借助 chrome 定位到每个 ...
- Linux oracle数据库创建表空间、用户并赋予权限
管理员用户登录oracle数据库 1.创建临时表空间 select name from v$tempfile;查出当前数据库临时表空间,主要是使用里面的存放路径: 得到其中一条记录/opt/oracl ...
- Zabbix的自定义键值和自动发现功能监控Oracle数据库的表空间
前面介绍了利用Orabbix监控了,参考zabbix通过Orabbix监控oracle数据库,这里我们原先的模板中进行了修改,使用自动发现功能实现监控tablespace的使用情况. 1. 在被监控的 ...
- Kafka与Flink集成
Apache Flink是新一代的分布式流式数据处理框架,它统一的处理引擎既可以处理批数据(batch data)也可以处理流式数据(streaming data).在实际场景中,Flink利用Apa ...
- Linux 排错 误删 /etc/fstab 和 /boot怎样恢复
实验:在分区情况下,rm -rf /boot和/etc/fstab,恢复 首先我们查看一下/etc/fstab 里面放的是什么东西,从下图可以看出里面存放的是分区的挂载情况,删除分区将不能自动挂载 接 ...
- 使用__FILE__和__LINE__定位错误
#include <stdio.h> int main() { printf("this fake error is in %s on line %d\n", __FI ...