7.26 简单计算几何

2024-04-10 18:38
文章标签 简单 计算 几何 7.26

本文主要是介绍7.26 简单计算几何,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

向量加减法,长度,数乘


代码实现

Pt operator - (Pt a,Pt b){
return Pt(a.x-b.x,a.y-b.y);}
Pt operator + (Pt a, Pt b){
return Pt(a.x + b.x, a.y + b.y); }
double Length ( Point q){
return sqrt (q.x*q.x+q.y*q.y); }
Pt operator * ( double A, Pt p){
return Pt(p.x*A, p.y*A); }

 

点积

double dot (Pt a, Pt b) {
return a.x * b.x + a.y * b.y; }
double Angle ( Vector A, Vector B) {
return acos ( dot(A,B)/ Length (A)/ Length (B ));}

叉积

double det (Pt a, Pt b) {
return a.x * b.y - a.y * b.x; }

 

点在直线上的判断,直线间的关系

点在线段上的判断

bool PtOnSegment (Pt s, Pt t, Pt a) {
return ! det (a-s,a-t)&& min (s.x,t.x)<=a.x &&
a.x <= max(s.x,t.x)&& min(s.y, t.y) <= a.y &&
a.y <= max(s.y, t.y);
}
bool PtOnSegment (Pt p, Pt a, Pt b) {
return ! sgn (det (p-a,b-a ))&& sgn (dot (p-a,p-b)) <=0;
}

线段间的关系

这里写图片描述

点到线段的距离

求点P到线段AB的最短距离
1.判断线段PA和AB所成的夹角,如果是钝角,那么jPAj是
点到线段的最短距离。
2.判断线段PB和AB所成的夹角,如果是钝角,那么jPBj是
点到线段的最短距离。
3.线段PA和线段PB与AB所成的夹角都不为钝角,那么
点P到线段AB的距离是点P到直线AB的距离,这个距离可
以用面积法直接算出来。

求三角形的面积

判断点是否在三角形内

重心

Pt triangleMassCenter (Pt a, Pt b, Pt c) {
return (a+b+c) / 3.0;}

求多边形的面积

//代码实现多边形的有向面积,这里返回正值
double PolygonArea (Pt* p,int n){
double area =0;
for (int i=1;i<n -1; i++)
area += det (p[i]-p[0] ,p[i+1] -p [0]);
return fabs ( area /2);
}

多边形内格点数

Pick公式

//代码实现:求多边形边界上的点数:可以当成伪代码来看
int polygon_border_point_cnt ( const Polygon &p) {
int ans = 0;
int n = p. size ();
for (int i = 0; i < n; ++i)
ans += gcd (Abs (int (p[ next (i)].x-p[i].x)),
Abs(int(p[ next (i)].y-p[i].y )));
return ans ;
}

凸包 

定义:凸包就是把给定点包围在内部的、面积最小的凸多边形

算法:Andrew算法

首先把所有点按照从小到大排序(如果x相同,按照y从小到大排
序),删除重复点后得到序列p1; p2; :::,然后把p1和p2放到凸包
中。从p3开始,当新点在凸包“前进”方向的左边时继续,否则
依次删除最近加入凸包的点,直到新点在左边。
注意:从左到右和从右到左各扫描一次

 

 

 

这篇关于7.26 简单计算几何的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/891836

相关文章

Python中Request的安装以及简单的使用方法图文教程

《Python中Request的安装以及简单的使用方法图文教程》python里的request库经常被用于进行网络爬虫,想要学习网络爬虫的同学必须得安装request这个第三方库,:本文主要介绍P... 目录1.Requests 安装cmd 窗口安装为pycharm安装在pycharm设置中为项目安装req

SpringBoot简单整合ElasticSearch实践

《SpringBoot简单整合ElasticSearch实践》Elasticsearch支持结构化和非结构化数据检索,通过索引创建和倒排索引文档,提高搜索效率,它基于Lucene封装,分为索引库、类型... 目录一:ElasticSearch支持对结构化和非结构化的数据进行检索二:ES的核心概念Index:

GO语言实现串口简单通讯

《GO语言实现串口简单通讯》本文分享了使用Go语言进行串口通讯的实践过程,详细介绍了串口配置、数据发送与接收的代码实现,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要... 目录背景串口通讯代码代码块分解解析完整代码运行结果背景最近再学习 go 语言,在某宝用5块钱买了个

SpringBoot整合Apache Spark实现一个简单的数据分析功能

《SpringBoot整合ApacheSpark实现一个简单的数据分析功能》ApacheSpark是一个开源的大数据处理框架,它提供了丰富的功能和API,用于分布式数据处理、数据分析和机器学习等任务... 目录第一步、添加android依赖第二步、编写配置类第三步、编写控制类启动项目并测试总结ApacheS

C++简单日志系统实现代码示例

《C++简单日志系统实现代码示例》日志系统是成熟软件中的一个重要组成部分,其记录软件的使用和运行行为,方便事后进行故障分析、数据统计等,:本文主要介绍C++简单日志系统实现的相关资料,文中通过代码... 目录前言Util.hppLevel.hppLogMsg.hppFormat.hppSink.hppBuf

Python实现简单封装网络请求的示例详解

《Python实现简单封装网络请求的示例详解》这篇文章主要为大家详细介绍了Python实现简单封装网络请求的相关知识,文中的示例代码讲解详细,感兴趣的小伙伴可以跟随小编一起学习一下... 目录安装依赖核心功能说明1. 类与方法概览2.NetHelper类初始化参数3.ApiResponse类属性与方法使用实

Python实现精确小数计算的完全指南

《Python实现精确小数计算的完全指南》在金融计算、科学实验和工程领域,浮点数精度问题一直是开发者面临的重大挑战,本文将深入解析Python精确小数计算技术体系,感兴趣的小伙伴可以了解一下... 目录引言:小数精度问题的核心挑战一、浮点数精度问题分析1.1 浮点数精度陷阱1.2 浮点数误差来源二、基础解决

Python 基于http.server模块实现简单http服务的代码举例

《Python基于http.server模块实现简单http服务的代码举例》Pythonhttp.server模块通过继承BaseHTTPRequestHandler处理HTTP请求,使用Threa... 目录测试环境代码实现相关介绍模块简介类及相关函数简介参考链接测试环境win11专业版python

Python文本相似度计算的方法大全

《Python文本相似度计算的方法大全》文本相似度是指两个文本在内容、结构或语义上的相近程度,通常用0到1之间的数值表示,0表示完全不同,1表示完全相同,本文将深入解析多种文本相似度计算方法,帮助您选... 目录前言什么是文本相似度?1. Levenshtein 距离(编辑距离)核心公式实现示例2. Jac

python连接sqlite3简单用法完整例子

《python连接sqlite3简单用法完整例子》SQLite3是一个内置的Python模块,可以通过Python的标准库轻松地使用,无需进行额外安装和配置,:本文主要介绍python连接sqli... 目录1. 连接到数据库2. 创建游标对象3. 创建表4. 插入数据5. 查询数据6. 更新数据7. 删除