poj 1269 Intersecting Lines——叉积求直线交点坐标
题目:http://poj.org/problem?id=1269
相关知识:
叉积
求面积:https://www.cnblogs.com/xiexinxinlove/p/3708147.html
什么是叉积:https://blog.csdn.net/sunbobosun56801/article/details/78980467
其二维:https://blog.csdn.net/qq_38182397/article/details/80508303
计算交点:
方法1:面积的比例:https://blog.csdn.net/dgq8211/article/details/7952825
方法2:叉积:https://blog.csdn.net/hktkfly6/article/details/69218777
(其原因:https://www.jianshu.com/p/3468c9967fc7)
例题:POJ1269:https://www.xuebuyuan.com/1979631.html
此题的链接使用的就是那个面积比例的方法。但自己不是很懂,所以用了那个另一种方法。
利用面积算交点坐标应该还可以:https://www.cnblogs.com/Narh/p/9663099.html
设直线有两个参数:p->起点坐标;t->终点坐标减起点坐标。设有线段 a 和 b 。设交点为 r 。
double d=( (a.p-b.p)×a.t ) / ( b.t×a.t ) ,r = a.p + d * a.t ;
那个 d 就是面积比,即交点与一条线段的相对该线段起点的坐标值之比。
画一画,分子就是三角形面积的两倍,分母是那样的平行四边形的面积,但连一下发现它就是两线交叉的那个四边形的面积的两倍。面积比即高的比即那两段线段之比。
关于这种方法的 a、b、c 怎么算,可以这样想:y=k*x+b 又 a*x+b*y+c=0 ,所以 a : b : c = -k : 1 : b;
已知一条直线的两个点的坐标,联立可得 k=( y1-y2 ) / ( x1-x2 ) ; b=( x1*y2 - y1*x2 ) / ( x1-x2 ) ;
所以 a : b : c = ( y2-y1) : ( x1-x2 ) : ( x1*y2 - y1*x2 ) 。可以说它们就等于这个,因为另一侧是0,可以随便乘。
#include<iostream>
#include<cstdio>
#include<cstring>
#include<algorithm>
#define db double
using namespace std;
int T,tx,ty;
struct Pt{
db x,y;
Pt(db x=,db y=):x(x),y(y) {}
}ta,tb;
struct Line{
Pt p,t;
}a,b;
int operator* (const Pt &a,const Pt &b)
{return a.x*b.y-a.y*b.x;}
Pt operator- (const Pt &a,const Pt &b)
{return Pt(a.x-b.x,a.y-b.y);}
int check(Line a,Line b)
{
int d1=(b.p-a.p)*(a.t-a.p);
int d2=(b.t-a.p)*(a.t-a.p);
if(!d1&&!d2) return -;//line
if(d1==d2) return ;//none
if(d1*d2<=) return ;//point ==0 for 端点相交
}
Pt find(Line a,Line b)
{
db x1=a.p.x,y1=a.p.y,x2=a.t.x,y2=a.t.y;
db a0=y2-y1,b0=x1-x2,c0=y1*x2-x1*y2;
x1=b.p.x,y1=b.p.y,x2=b.t.x,y2=b.t.y;
db a1=y2-y1,b1=x1-x2,c1=y1*x2-x1*y2;
int tmp=a0*b1-a1*b0;
return Pt((b0*c1-b1*c0)/tmp,(-a0*c1+a1*c0)/tmp);
}
int main()
{
scanf("%d",&T);
puts("INTERSECTING LINES OUTPUT");
while(T--)
{
scanf("%d%d",&tx,&ty); ta=Pt(tx,ty);
scanf("%d%d",&tx,&ty); tb=Pt(tx,ty);
a.p=ta; a.t=tb;
scanf("%d%d",&tx,&ty); ta=Pt(tx,ty);
scanf("%d%d",&tx,&ty); tb=Pt(tx,ty);
b.p=ta; b.t=tb;
int d=check(a,b);
if(d==-) puts("LINE");
else if(d==) puts("NONE");
else
{
printf("POINT ");
Pt c=find(a,b);
printf("%.2lf %.2lf\n",c.x,c.y);
}
}
puts("END OF OUTPUT");
return ;
}
poj 1269 Intersecting Lines——叉积求直线交点坐标的更多相关文章
- POJ 1269 Intersecting Lines【判断直线相交】
题意:给两条直线,判断相交,重合或者平行 思路:判断重合可以用叉积,平行用斜率,其他情况即为相交. 求交点: 这里也用到叉积的原理.假设交点为p0(x0,y0).则有: (p1-p0)X(p2-p0) ...
- POJ 1269 Intersecting Lines(判断两直线位置关系)
题目传送门:POJ 1269 Intersecting Lines Description We all know that a pair of distinct points on a plane ...
- 判断两条直线的位置关系 POJ 1269 Intersecting Lines
两条直线可能有三种关系:1.共线 2.平行(不包括共线) 3.相交. 那给定两条直线怎么判断他们的位置关系呢.还是用到向量的叉积 例题:POJ 1269 题意:这道题是给定四个点p1, ...
- poj 1269 Intersecting Lines
题目链接:http://poj.org/problem?id=1269 题目大意:给出四个点的坐标x1,y1,x2,y2,x3,y3,x4,y4,前两个形成一条直线,后两个坐标形成一条直线.然后问你是 ...
- POJ 1269 - Intersecting Lines - [平面几何模板题]
题目链接:http://poj.org/problem?id=1269 Time Limit: 1000MS Memory Limit: 10000K Description We all know ...
- ●POJ 1269 Intersecting Lines
题链: http://poj.org/problem?id=1269 题解: 计算几何,直线交点 模板题,试了一下直线的向量参数方程求交点的方法. (方法详见<算法竞赛入门经典——训练指南> ...
- POJ 1269 Intersecting Lines(直线求交点)
Description We all know that a pair of distinct points on a plane defines a line and that a pair of ...
- POJ 1269 Intersecting Lines(直线相交判断,求交点)
Intersecting Lines Time Limit: 1000MS Memory Limit: 10000K Total Submissions: 8342 Accepted: 378 ...
- poj 1269 Intersecting Lines(判断两直线关系,并求交点坐标)
Intersecting Lines Time Limit: 1000MS Memory Limit: 10000K Total Submissions: 12421 Accepted: 55 ...
随机推荐
- 结缘mac
还记得上一次买MacBookPro.是在去年的7月下旬,记得那次是我大学第一次买电脑,那时候刚准备開始研究android.听stormzhang以及android开发界的大佬们对mac开发androi ...
- PythonCookBook笔记——函数
函数 可接受任意数量参数的函数 接受任意数量的位置参数,使用*参数. 接受任意数量的关键字参数,使用**参数. 只接受关键字参数的函数 强制关键字参数放在某个参数后或直接单个之后. 给函数参数增加元信 ...
- PowerBuilder -- 变更某列的背景色
记得把background.mode设置为2 li_col++ ls_col[li_col] = ls_fit_no ls_column = ' col' + String(li_col) ls_co ...
- mac os x升级MOUNTAIN LION后svn command not found的解决
因为svn是个开发工具 所以苹果把他移到 Xcode developer package 里 去了,所以你没装xcode之类的,先去AppStore把xcode装了 装好之后sudo vi /et ...
- ios -- 延迟3秒触发performSelector
[self performSelector:@selector(changeText:) withObject:@"Happy aha" afterDelay:3];
- vue-cli3.0升级失败,vue-cli卸载不掉,vue-cli升级不了3.0
https://juejin.im/post/5bf7d67c51882518805acb1a vue-cli3.0 使用图形化界面创建和管理项目
- IOS GameCenter验证登陆
#import "GameKitHelper.h" #import "GameConstants.h" @interface GameKitHelper () ...
- 1194: [HNOI2006]潘多拉的盒子
1194: [HNOI2006]潘多拉的盒子 Time Limit: 10 Sec Memory Limit: 162 MBSubmit: 464 Solved: 221[Submit][Stat ...
- UITableView的headerView和headerInsectionView
UITableView有两个headerView:tableHeaderView.和headerInsectionView(组头视图). 给tableView添加这两个View:tableHead ...
- apache vhosts 虚拟主机设置
编辑vhosts文件:/alidata/server/httpd-2.4.10/conf/extra/httpd-vhosts.conf <VirtualHost *:80> <Lo ...