首页 技术 正文
技术 2022年11月15日
0 收藏 363 点赞 3,668 浏览 1443 个字

题目链接

题意 : 给你两条线段的起点和终点,一共四个点,让你求交点坐标,如果这四个点是共线的,输出“LINE”,如果是平行的就输出“NONE”。

思路 : 照着ZN留下的模板果然好用,直接套上模板了事儿,不过在判断是否共线的时候,其实还有另一种方法,直接将平行和共线一起判断了,我是判断三个点三个点的判断是否是共线。

 //
#include <stdio.h>
#include <string.h>
#include <iostream> using namespace std ; #define eps 1e-8
#define zero(x) (((x)>0?(x):-(x))<eps)
typedef struct
{
double x,y ;
} point ;
typedef struct
{
point a,b ;
} line ; //计算cross product (P1-P0)x(P2-P0)
double xmult(double x1,double y1,double x2,double y2,double x0,double y0)
{
return (x1-x0)*(y2-y0)-(x2-x0)*(y1-y0);
} //判三点共线
int dots_inline(double x1,double y1,double x2,double y2,double x3,double y3)
{
return zero(xmult(x1,y1,x2,y2,x3,y3));
} //线段交点请另外判线段相交(同时还是要判断是否平行!)
point intersection(point u1,point u2,point v1,point v2)
{
point ret=u1;
double t=((u1.x-v1.x)*(v1.y-v2.y)-(u1.y-v1.y)*(v1.x-v2.x))/((u1.x-u2.x)*(v1.y-v2.y)-(u1.y-u2.y)*(v1.x-v2.x));
ret.x+=(u2.x-u1.x)*t;
ret.y+=(u2.y-u1.y)*t;
return ret;
} int parallel(point u1,point u2,point v1,point v2)
{
return zero((u1.x-u2.x)*(v1.y-v2.y)-(v1.x-v2.x)*(u1.y-u2.y));
} int main()
{
int n ;
scanf("%d",&n) ;
point p1,q1,p2,q2 ;
printf("INTERSECTING LINES OUTPUT\n") ;
for(int i = ; i < n ; i++)
{
scanf("%lf %lf %lf %lf",&p1.x,&p1.y,&p2.x,&p2.y) ;
scanf("%lf %lf %lf %lf",&q1.x,&q1.y,&q2.x,&q2.y) ;
if(dots_inline(p1.x,p1.y,p2.x,p2.y,q1.x,q1.y)&&dots_inline(p1.x,p1.y,p2.x,p2.y,q2.x,q2.y))
printf("LINE\n") ;
else if(parallel(p1,p2,q1,q2))
printf("NONE\n") ;
else
{
point ret = intersection(p1,p2,q1,q2) ;
printf("POINT %.2lf %.2lf\n",ret.x,ret.y) ;
}
}
printf("END OF OUTPUT\n") ;
return ;
}

还有一点要注意,因为涉及到lf和f的问题,所以要看是交C++还是G++ 。

相关推荐
python开发_常用的python模块及安装方法
adodb:我们领导推荐的数据库连接组件bsddb3:BerkeleyDB的连接组件Cheetah-1.0:我比较喜欢这个版本的cheeta…
日期:2022-11-24 点赞:878 阅读:9,492
Educational Codeforces Round 11 C. Hard Process 二分
C. Hard Process题目连接:http://www.codeforces.com/contest/660/problem/CDes…
日期:2022-11-24 点赞:807 阅读:5,907
下载Ubuntn 17.04 内核源代码
zengkefu@server1:/usr/src$ uname -aLinux server1 4.10.0-19-generic #21…
日期:2022-11-24 点赞:569 阅读:6,740
可用Active Desktop Calendar V7.86 注册码序列号
可用Active Desktop Calendar V7.86 注册码序列号Name: www.greendown.cn Code: &nb…
日期:2022-11-24 点赞:733 阅读:6,494
Android调用系统相机、自定义相机、处理大图片
Android调用系统相机和自定义相机实例本博文主要是介绍了android上使用相机进行拍照并显示的两种方式,并且由于涉及到要把拍到的照片显…
日期:2022-11-24 点赞:512 阅读:8,132
Struts的使用
一、Struts2的获取  Struts的官方网站为:http://struts.apache.org/  下载完Struts2的jar包,…
日期:2022-11-24 点赞:671 阅读:5,295