c++ 判断点和折线 距离

2024-05-02 22:36
文章标签 c++ 判断 距离 折线

本文主要是介绍c++ 判断点和折线 距离,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

目录

c++ 一个点a ,一条折线(n个点)b,求折线b上 与a x相同时 y方向的差异

判断点是否在折线下方:


c++ 一个点a ,一条折线(n个点)b,求折线b上 与a x相同时 y方向的差异

#include <iostream>
#include <vector>
#include <cmath>
#include <limits>struct Point {double x, y;
};double calculateYDifferenceToPolyline(const std::vector<Point>& polyline, const Point& a) {double minDifference = std::numeric_limits<double>::infinity();for (size_t i = 0; i < polyline.size() - 1; ++i) {const Point& P1 = polyline[i];const Point& P2 = polyline[i + 1];// 检查点 a 是否在 P1 和 P2 之间的 x 范围内if ((a.x >= P1.x && a.x <= P2.x) || (a.x >= P2.x && a.x <= P1.x)) {// 计算 a 在 P1 -> P2 线段上的对应 y 坐标double yLine = P1.y + (P2.y - P1.y) * (a.x - P1.x) / (P2.x - P1.x);// 计算 y 方向上的差异double difference = a.y - yLine;// 更新最小差异minDifference = std::min(minDifference, std::abs(difference));}}return minDifference;
}int main() {// 定义折线std::vector<Point> polyline = {{1.0, 1.0}, {2.0, 3.0}, {3.0, 3.0}, {4.0, 5.0}, {5.0, 5.0}, {6.0, 7.0}};// 定义需要判断的点Point a = { 3.5, 3.5 };// 计算 a 与折线段的 y 方向差异double difference = calculateYDifferenceToPolyline(polyline, a);std::cout << "dis: " << difference << " units." << std::endl;return 0;
}

判断点是否在折线下方:

#include <iostream>
#include <vector>struct Point {double x, y;
};int checkPointRelativeToPolyline(const std::vector<Point>& polyline, const Point& P3) {int isBelow = 0;for (size_t i = 0; i < polyline.size() - 1; ++i) {const Point& P1 = polyline[i];const Point& P2 = polyline[i + 1];// 计算向量叉积double crossProduct = (P2.x - P1.x) * (P3.y - P1.y) - (P2.y - P1.y) * (P3.x - P1.x);if (crossProduct < 0) {isBelow = 1;}}return isBelow;}int main() {// 定义折线std::vector<Point> polyline = {{1.0, 1.0}, {2.0, 3.0}, {3.0, 3.0}, {4.0, 5.0}, {5.0, 5.0}, {6.0, 7.0}};// 定义需要判断的点Point P3 = { 3.5, 4.0 };// 检查 P3 相对于折线的每个线段的位置checkPointRelativeToPolyline(polyline, P3);return 0;
}

这篇关于c++ 判断点和折线 距离的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



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

相关文章

Windows下C++使用SQLitede的操作过程

《Windows下C++使用SQLitede的操作过程》本文介绍了Windows下C++使用SQLite的安装配置、CppSQLite库封装优势、核心功能(如数据库连接、事务管理)、跨平台支持及性能优... 目录Windows下C++使用SQLite1、安装2、代码示例CppSQLite:C++轻松操作SQ

C++中RAII资源获取即初始化

《C++中RAII资源获取即初始化》RAII通过构造/析构自动管理资源生命周期,确保安全释放,本文就来介绍一下C++中的RAII技术及其应用,具有一定的参考价值,感兴趣的可以了解一下... 目录一、核心原理与机制二、标准库中的RAII实现三、自定义RAII类设计原则四、常见应用场景1. 内存管理2. 文件操

C++中零拷贝的多种实现方式

《C++中零拷贝的多种实现方式》本文主要介绍了C++中零拷贝的实现示例,旨在在减少数据在内存中的不必要复制,从而提高程序性能、降低内存使用并减少CPU消耗,零拷贝技术通过多种方式实现,下面就来了解一下... 目录一、C++中零拷贝技术的核心概念二、std::string_view 简介三、std::stri

C++高效内存池实现减少动态分配开销的解决方案

《C++高效内存池实现减少动态分配开销的解决方案》C++动态内存分配存在系统调用开销、碎片化和锁竞争等性能问题,内存池通过预分配、分块管理和缓存复用解决这些问题,下面就来了解一下... 目录一、C++内存分配的性能挑战二、内存池技术的核心原理三、主流内存池实现:TCMalloc与Jemalloc1. TCM

python判断文件是否存在常用的几种方式

《python判断文件是否存在常用的几种方式》在Python中我们在读写文件之前,首先要做的事情就是判断文件是否存在,否则很容易发生错误的情况,:本文主要介绍python判断文件是否存在常用的几种... 目录1. 使用 os.path.exists()2. 使用 os.path.isfile()3. 使用

C++ 函数 strftime 和时间格式示例详解

《C++函数strftime和时间格式示例详解》strftime是C/C++标准库中用于格式化日期和时间的函数,定义在ctime头文件中,它将tm结构体中的时间信息转换为指定格式的字符串,是处理... 目录C++ 函数 strftipythonme 详解一、函数原型二、功能描述三、格式字符串说明四、返回值五

C++作用域和标识符查找规则详解

《C++作用域和标识符查找规则详解》在C++中,作用域(Scope)和标识符查找(IdentifierLookup)是理解代码行为的重要概念,本文将详细介绍这些规则,并通过实例来说明它们的工作原理,需... 目录作用域标识符查找规则1. 普通查找(Ordinary Lookup)2. 限定查找(Qualif

Go语言如何判断两张图片的相似度

《Go语言如何判断两张图片的相似度》这篇文章主要为大家详细介绍了Go语言如何中实现判断两张图片的相似度的两种方法,文中的示例代码讲解详细,感兴趣的小伙伴可以跟随小编一起学习一下... 在介绍技术细节前,我们先来看看图片对比在哪些场景下可以用得到:图片去重:自动删除重复图片,为存储空间"瘦身"。想象你是一个

C/C++ chrono简单使用场景示例详解

《C/C++chrono简单使用场景示例详解》:本文主要介绍C/C++chrono简单使用场景示例详解,本文通过实例代码给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友... 目录chrono使用场景举例1 输出格式化字符串chrono使用场景China编程举例1 输出格式化字符串示

C++/类与对象/默认成员函数@构造函数的用法

《C++/类与对象/默认成员函数@构造函数的用法》:本文主要介绍C++/类与对象/默认成员函数@构造函数的用法,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录名词概念默认成员函数构造函数概念函数特征显示构造函数隐式构造函数总结名词概念默认构造函数:不用传参就可以