计算几何
大约 1 分钟约 369 字
计算几何
点线关系
点的结构体如下:
struct Point {
double x, y;
};
点积
定义:
几何意义:向量b在向量a上的投影与向量a的长度的乘积
坐标运算:
应用
- 两向量垂直:
- 两向量平行:
- 两向量夹角:
data:image/s3,"s3://crabby-images/c32e9/c32e989100e42ec3261b4d263ace2c9eb82f7a09" alt="image-20230822184201417"
叉积
定义:
几何意义:两个向量形成的平行四边形的面积,b在a逆时针方向为正
运算:
应用:判断点线位置关系:
data:image/s3,"s3://crabby-images/94c48/94c48c19d7f659c63e227854a35b25af427b6329" alt="image-20230822184217460"
代码模版
struct Point {
double x, y;
Point operator+(Point b) const {
return {x + b.x, y + b.y};
}
Point operator-(Point b) const {
return {x - b.x, y - b.y};
}
double operator*(Point b) const { //点积
return x * b.x + y * b.y;
}
Point operator*(int t) const {
return {x * t, y * t};
}
double operator&(Point b) const {//叉积
return x * b.y - y * b.x;
}
};
double len(Point a) { //模
return sqrt(a.x * a.x + a.y * a.y);
}
double angle(Point a, Point b) { //cos夹角
double t = a * b / len(a) / len(b);
return acos(t);
}
double cross(Point a, Point b, Point c) { //两个向量叉积
return (c - a) & (b - a);//>0 c在ab左侧 =0 共线
}
double dis(Point a, Point b) {
double t = (a.x - b.x) * (a.x - b.x) + (a.y - b.y) * (a.y - b.y);
return sqrt(t);
}
线线关系
data:image/s3,"s3://crabby-images/22f89/22f8913a330c4d3a58fdb37be8cd08ee4dcacad2" alt="image-20230822194352884"
三角剖分
data:image/s3,"s3://crabby-images/2872a/2872a16051508f9b408e73995ab6d2afa7e8b771" alt="image-20230822201323976"