6-5 判单三点是否在一直线上
分数 10
全屏浏览
切换布局
作者 刘利
单位 惠州学院
输入三点坐标(题目保证输入点不相同),判断三点是否在一直线上,是输出“YES",不是则输出 “NO”。
题目已经定义好Point类,并编写了main函数,要求根据main函数的需求编写一个isLine的函数判断输入三个Point对象是否位于一条直线上。
函数接口定义:
根据main的需求定义isLine函数。
裁判测试程序样例:
#include<iostream>
#include<string>
using namespace std;
class Point{
public:
Point(double _x=0,double _y=0)
{
x=_x;
y=_y;
}
double getx()
{
return x;
}
double gety()
{
return y;
}
private:
double x,y;
};
/* 请在这里填写答案 */
int main()
{
double x1,y1,x2,y2,x3,y3;
cin>>x1>>y1>>x2>>y2>>x3>>y3;
Point p1(x1,y1),p2(x2,y2),p3(x3,y3);
if(isLine(p1,p2,p3))
cout<<"YES"<<endl;
else
cout<<"NO"<<endl;
}
输入样例1:
0 1 0 2 0 3
输出样例1:
YES
输入样例2:
2.3 3.4 5.8 7.9 9 10
输出样例2:
NO
输入样例3:
1 2 2 3 3 4
输出样例3:
YES
代码长度限制
16 KB
时间限制
400 ms
内存限制
64 MB
int isLine(Point &p1,Point &p2,Point &p3)
{
/*
if(p1.getx()*p2.gety()-p2.getx()*p1.gety()==0&&p2.getx()*p3.gety()-p3.getx()*p2.gety()==0&&p1.getx()*p3.gety()-p3.getx()*p1.gety()==0)
{
return 1;
}
*/
double line1x,line2x,line1y,line2y;
line1x = p1.getx()-p2.getx();
line2x = p2.getx()-p1.getx();
line1y = p1.gety()-p2.gety();
line2y = p3.gety()-p2.gety();
if(line1x*line2y-line2x*line1y==0){
return 1;
}
return 0;
}