点是否在线段上
两个条件
1.两个向量叉积为0;
2.点在线段端点矩形区域内;
#include <iostream>
#include <bits/stdc++.h>
using namespace std;
struct point{
double x;
double y;
};
bool onsegement(point pi,point pj,point q){
if((q.x-pi.x)*(pj.y-pi.y)==(pj.x-pi.x)*(q.y-pi.y)&&min(pi.x,pj.x)<=q.x&&q.x<=max(pi.x,pj.x)&&min(pi.y,pj.y)<=q.y&&q.y<=max(pi.y,pj.y)) return true;
return false;
}
int main()
{
point q,a,b;
cin>>q.x>>q.y>>a.x>>a.y>>b.x>>b.y;
if(onsegement(a,b,q)==true) printf("YES\n");
else printf("NO\n");
return 0;
}
【推荐】还在用 ECharts 开发大屏?试试这款永久免费的开源 BI 工具!
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步