We all know that a pair of distinct points on a plane defines a line and that a pair of lines on a plane will intersect in one of three ways: 1) no intersection because they are parallel, 2) intersect in a line because they are on top of one another (i.e. they are the same line), 3) intersect in a point. In this problem you will use your algebraic knowledge to create a program that determines how and where two lines intersect. 
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

The first line contains an integer N between 1 and 10 describing how many pairs of lines are represented. The next N lines will each contain eight integers. These integers represent the coordinates of four points on the plane in the order x1y1x2y2x3y3x4y4. Thus each of these input lines represents two lines on the plane: the line through (x1,y1) and (x2,y2) and the line through (x3,y3) and (x4,y4). The point (x1,y1) is always distinct from (x2,y2). Likewise with (x3,y3) and (x4,y4).

Output

There should be N+2 lines of output. The first line of output should read INTERSECTING LINES OUTPUT. There will then be one line of output for each pair of planar lines represented by a line of input, describing how the lines intersect: none, line, or point. If the intersection is a point then your program should output the x and y coordinates of the point, correct to two decimal places. The final line of output should read "END OF 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【计算几何】的更多相关文章

  1. 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 ...

  2. POJ1269:Intersecting Lines(判断两条直线的关系)

    题目:POJ1269 题意:给你两条直线的坐标,判断两条直线是否共线.平行.相交,若相交,求出交点. 思路:直线相交判断.如果相交求交点. 首先先判断是否共线,之后判断是否平行,如果都不是就直接求交点 ...

  3. POJ 1269 Intersecting Lines --计算几何

    题意: 二维平面,给两条线段,判断形成的直线是否重合,或是相交于一点,或是不相交. 解法: 简单几何. 重合: 叉积为0,且一条线段的一个端点到另一条直线的距离为0 不相交: 不满足重合的情况下叉积为 ...

  4. POJ1269 Intersecting Lines[线段相交 交点]

    Intersecting Lines Time Limit: 1000MS   Memory Limit: 10000K Total Submissions: 15145   Accepted: 66 ...

  5. [poj1269]Intersecting Lines

    题目大意:求两条直线的交点坐标. 解题关键:叉积的运用. 证明: 直线的一般方程为$F(x) = ax + by + c = 0$.既然我们已经知道直线的两个点,假设为$(x_0,y_0), (x_1 ...

  6. POJ1269 Intersecting Lines 2017-04-16 19:43 50人阅读 评论(0) 收藏

    Intersecting Lines Time Limit: 1000MS   Memory Limit: 10000K Total Submissions: 15478   Accepted: 67 ...

  7. POJ 1269 Intersecting Lines(计算几何)

    题意:给定4个点的坐标,前2个点是一条线,后2个点是另一条线,求这两条线的关系,如果相交,就输出交点. 题解:先判断是否共线,我用的是叉积的性质,用了2遍就可以判断4个点是否共线了,在用斜率判断是否平 ...

  8. POJ1269:Intersecting Lines——题解

    http://poj.org/problem?id=1269 题目大意:给四个点,求前两个点所构成的直线和后两个点所构成的直线的位置关系(平行,重合,相交),如果是相交,输出交点坐标. ——————— ...

  9. ●POJ 1269 Intersecting Lines

    题链: http://poj.org/problem?id=1269 题解: 计算几何,直线交点 模板题,试了一下直线的向量参数方程求交点的方法. (方法详见<算法竞赛入门经典——训练指南> ...

随机推荐

  1. maven的多环境配置

    <profiles> <profile> <id>dev</id> <activation> <activeByDefault> ...

  2. [转] NGUI自适应

    很多做移动终端开发的童鞋都可能遇到一个问题,就是如何自适应其实NGUI已经能帮我们实现,下面就告诉大家怎么整这个自适应.1,create a new ui 2,uiroot下添加uipanel(scr ...

  3. UINavigationController popToViewController用法

    popToViewController用法  [self.navigationController popToViewController:[self.navigationController.vie ...

  4. Hibernate_day02讲义_使用Hibernate完成CRM客户管理中查询所有客户的操作

  5. HttpClient(三)-- 抓取图片

    使用HttpClient抓取图片,先通过 entity.getContent() 获取输入流,然后 使用 common io 中的文件复制 方法 将图片专区到本地,代码如下: 1.需要依赖common ...

  6. C语言中一个字符数组里面的所有元素变成一个字符串

    #include <string.h> int main() // 这里为了方便直接用main函数 {     char array[] = { 'h', 'e', 'l', 'l', ' ...

  7. JQuery插件的使用

    今天就来总结一下jquery插件的使用,刚开始学习时间一直自己在写实现他的功能,现在发现jquery好强大啊,好多的功能都给我们封装好啦,jquery万岁,嘿嘿,下面就来简单的总结一下我们学习的:

  8. sqlite的一个Unable to Open database file的坑爹错误

    今天,被sqlite的一个机制给坑了.本人用C语言写的cgi程序去访问sqlite数据库,读取没有问题,但是插入新纪录和更新数据就不行,在服务器上直接对数据库进行增删查改则没有任何问题.但浏览器上访问 ...

  9. jQuery的parseHTML方法

    // data html字符串    // context 如果指定了context,则碎片将在此范围内被创建,默认是document    // keepScripts 如果是true,则将有scr ...

  10. Android 本地tomcat服务器接收处理手机上传的数据之环境搭建

    上一篇:Android 使用tomcat搭建HTTP文件下载服务器   本篇文章   环境:win7 + jdk1.7 + tomcat v8.0.53   工具: 1.Eclipse  Eclips ...