zoj 1280 Intersecting Lines(两直线交点)
2015-06-03 18:11
204 查看
题意:n组数据,每组两条直线两端点坐标,判断线段平行、重合,相交;
思路:利用叉积跨立实验判断重合与平行,交点公式求交点;zoj过了,可是poj1269一样的题,poj上把%lf都改为%.f才能AC。
思路:利用叉积跨立实验判断重合与平行,交点公式求交点;zoj过了,可是poj1269一样的题,poj上把%lf都改为%.f才能AC。
#include<cstdio> #include<cstring> #include<cmath> #include<algorithm> using namespace std; const double epsi=1e-10; inline int sign(const double &x){ if(x>epsi) return 1; if(x<-epsi) return -1; return 0; } struct point{ double x,y; point(double xx=0,double yy=0):x(xx),y(yy){} point operator -(const point &op2) const{ return point(x-op2.x,y-op2.y); } double operator ^(const point &op2) const{ return x*op2.y-y*op2.x; } }; inline double sqr(const double &x){ return x*x; } inline double mul(const point &p0,const point &p1,const point &p2){ return (p1-p0)^(p2-p0); } inline double dis2(const point &p0,const point &p1){ return sqr(p0.x-p1.x)+sqr(p0.y-p1.y); } inline double dis(const point &p0,const point &p1){ return sqrt(dis2(p0,p1)); } inline int cross(const point &p1,const point &p2,const point &p3,const point &p4,point &p){ double a1=mul(p1,p2,p3),a2=mul(p1,p2,p4); if(sign(a1)==0&&sign(a2)==0) return 2;//重叠 if(sign(a1-a2)==0) return 0; p.x=(a2*p3.x-a1*p4.x)/(a2-a1); p.y=(a2*p3.y-a1*p4.y)/(a2-a1); //利用公式计算交点 return 1; } point p1,p2,p3,p4,p; int main() { int test=0; scanf("%d",&test); printf("INTERSECTING LINES OUTPUT\n"); while(test--){ scanf("%lf%lf%lf%lf%lf%lf%lf%lf",&p1.x,&p1.y,&p2.x,&p2.y,&p3.x,&p3.y,&p4.x,&p4.y); int m=cross(p1,p2,p3,p4,p); if(m==0) printf("NONE\n"); else if(m==2) printf("LINE\n"); else printf("POINT %.2lf %.2lf\n",p.x,p.y); } printf("END OF OUTPUT\n"); return 0; }
相关文章推荐
- 适配 - autolayout自动布局
- leetcode 218: The Skyline Problem
- 48.核心动画之基础动画
- 父窗口中获取iframe中的元素
- 一个从全部解中找到pareto-front的方法的实现
- Linux下常用的C/C++开源Socket库
- Android网络通信的六种方式示例代码
- pg_restore - 从一个由 pg_dump 创建的备份文件中恢复 PostgreSQL 数据库。
- Linux下常用的C/C++开源Socket库
- s2010编译C++ 链栈的使用
- .NET Framework 框架简述01
- Volley cancel
- XCode调试应用程序
- swift开发ios笔记2--汤姆猫动画(帧动画)
- Android Handler的使用
- 今日总结20150603
- mule esb exception(一)
- 控制android 编译源码生成odex .
- iOS中图片拉伸技巧
- ios开发之Swift新手入门