poj 1269 判断两直线位置
来源:互联网 发布:霜之哀伤淘宝 编辑:程序博客网 时间:2024/04/30 10:46
题意:给两个点能够确定一条直线,题目给出两条直线(由4个点确定),要求判断出这两条直线的关系:平行,同线,相交。如果相交还要求出交点坐标。
思路:分类讨论。先按照斜率是否存在进行分类。然后在各自小类中继续分类求解。具体分类情况见注释。
#include <stdio.h>#include <string.h>double getk(int x1,int y1,int x2,int y2){//将直线表示成y=kx+b,此函数求k值 return (double)(y2-y1)/(x2-x1);}double getb(int x1,int y1,int x2,int y2){//此函数求b值 return (double)(x2*y1-x1*y2)/(x2-x1);}int main(){ int T,x1,x2,x3,x4,y1,y2,y3,y4; double k1,k2,b1,b2; printf("INTERSECTING LINES OUTPUT\n"); scanf("%d",&T); while(T--){ scanf("%d %d %d %d",&x1,&y1,&x2,&y2); scanf("%d %d %d %d",&x3,&y3,&x4,&y4); if(x1==x2 || x3==x4){ if(x1==x2){ if(x3==x4){//两条直线斜率都不存在 if(x1==x3)//共线 printf("LINE\n"); else printf("NONE\n"); }else{//求出斜率存在的那条直线的k值和b值 k1 = getk(x3,y3,x4,y4); b1 = getb(x3,y3,x4,y4); printf("POINT %.2lf %.2lf\n",(double)x1,k1*x1+b1); } }else{ k1 = getk(x1,y1,x2,y2); b1 = getb(x1,y1,x2,y2); printf("POINT %.2lf %.2lf\n",(double)x3,k1*x3+b1); } }else{//如果两天直线的斜率都存在 k1 = getk(x1,y1,x2,y2); k2 = getk(x3,y3,x4,y4); b1 = getb(x1,y1,x2,y2); b2 = getb(x3,y3,x4,y4); if(k1 == k2){//斜率相等 if(b1 == b2) printf("LINE\n"); else printf("NONE\n"); }else//不等 printf("POINT %.2lf %.2lf\n",(b1-b2)/(k2-k1),(b1*k2-b2*k1)/(k2-k1)); } } printf("END OF OUTPUT\n"); return 0;}
0 0
- poj 1269 判断两直线位置
- poj 1269 Intersecting Lines (叉积 判断两直线位置关系)
- POJ 1269 直线位置关系的判断
- POJ 1269 Intersecting Lines(判断两直线的位置关系)
- POJ 1269 Intersecting Lines(判断两条直线的位置关系)
- poj 1269判断两条直线的位置关系 以及求交点
- poj 1269 两条直线的位置关系
- POJ 1269 Intersecting Lines(判断直线的位置关系)
- poj 1269 Intersecting Lines 判断直线的位置关系
- POJ - 1269:Intersecting Lines__判断两直线相交
- POJ 1269 Intersecting Lines(判断两条直线关系)
- POJ 1269 Intersecting Lines(判断两直线关系)
- poj 1269 判断两直线的关系并求交点
- poj 1269 Intersecting Lines 【判断两条直线的关系】
- POJ 1269 判断直线与直线相交
- POJ 1269 判断直线和直线关系
- Intersecting Lines(判断两条直线的位置,模板)
- POJ 1269 Intersecting Lines (两直线之间的位置关系)
- 键盘上方自定义view
- CSS布局模型(三)——层模型
- HDU 2147 kiki's game 博弈
- HDU 1540 Tunnel Warfare 线段树
- ACM——01——1006: 【入门】倒序输出一个四位整数 【运算符】
- poj 1269 判断两直线位置
- label 首行缩进
- Socket常见错误代码与描述
- SQL sever2008服务无法启动,提示“远程过程调试失败···”
- 加载数据
- 二维标准正态分布的matlab方程
- eclipse中使用svn
- 需要注意的
- textView 退回键盘