IT数码 购物 网址 头条 软件 日历 阅读 图书馆
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
图片批量下载器
↓批量下载图片,美女图库↓
图片自动播放器
↓图片自动播放器↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁
 
   -> 数据结构与算法 -> 计算几何-寻找凸包 -> 正文阅读

[数据结构与算法]计算几何-寻找凸包

问题定义

一个点集 Σ \Sigma Σ的凸包是一个面积最小的凸多边形 P P P,满足点集中每个节点都在P的边界或者P的内部。

显然,凸包中每个顶点都是点集中的点。

主要方法

  • 增量法(Incremental method),对点集进行从左到右排序,在第 i i i步中,根据前 i i i个节点形成是的凸包对第i个节点进行考察,是否加入p中。时间复杂度为 O ( n lg ? n ) O(n\lg n ) O(nlgn)
  • 分治法,将点集分为最左边 n 2 \frac{n}{2} 2n?个节点和最右边 n 2 \frac{n}{2} 2n?节点,分别对这两部分进行递归计算。然后使用一种 O ( n ) O(n) O(n)的方法进行合并。 T ( n ) = 2 T ( n 2 ) + O ( n ) T(n) = 2T(\frac{n}{2}) + O(n) T(n)=2T(2n?)+O(n)可以得到 T ( n ) = O ( n lg ? n ) T(n) = O(n\lg n) T(n)=O(nlgn)
  • 剪枝搜索。
  • 旋转扫除法,下面介绍的两种算法都是采用的该种方法。该方法通过类似旋转的过程,每次逐步完成凸包的构建。

Graham扫描法

它是按照以下流程进行的:

  1. 选择纵坐标最小的节点作为基准点 p 0 p_0 p0?(如果存在多个则选择横坐标最小的点)
  2. 根据 p 0 p_0 p0?对剩下的所有节点按照和 p 0 p_0 p0?的极角进行排序。
  3. p 0 , 和 排 序 后 的 p 1 , p 2 p_0,和排序后的p_1,p_2 p0?,p1?,p2?加入一个栈内。
  4. 考察第 i i i个节点 p i p_i pi?,如果该节点和栈中的栈顶 l 0 l_0 l0?,栈次顶 l 1 l_1 l1?构成一个左转,那么将 p i p_i pi?加入栈中,否则删除节点 l 0 l_0 l0?,然后重复操作4,直到满足前一条件,或者栈中元素少于2.
  5. 程序结束,栈中元素即是凸包的逆时针序列。伪代码

在这里插入图片描述

Javis步进法

  • 该算法的主要思路即每次寻找极角最小的点作为凸包。
  1. 寻找和Graham一样的 p 0 p_0 p0?点。
  2. 以该点为基准点,寻找极角最小的点,并以该节点为新的基准点重复步骤2.
  3. 如果步骤2发现的新的基准点为 p 0 p_0 p0?则结束循环。步骤2中发现的基准点即为凸包。

Javis
==对于极角的比较,以及是否左转用到的都是点的叉乘,参见点的叉乘

备注:文中所有图片出自《算法导论》

  数据结构与算法 最新文章
【力扣106】 从中序与后续遍历序列构造二叉
leetcode 322 零钱兑换
哈希的应用:海量数据处理
动态规划|最短Hamilton路径
华为机试_HJ41 称砝码【中等】【menset】【
【C与数据结构】——寒假提高每日练习Day1
基础算法——堆排序
2023王道数据结构线性表--单链表课后习题部
LeetCode 之 反转链表的一部分
【题解】lintcode必刷50题<有效的括号序列
上一篇文章      下一篇文章      查看所有文章
加:2022-01-04 13:41:40  更:2022-01-04 13:42:47 
 
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁

360图书馆 购物 三丰科技 阅读网 日历 万年历 2024年11日历 -2024/11/26 17:35:17-

图片自动播放器
↓图片自动播放器↓
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
图片批量下载器
↓批量下载图片,美女图库↓
  网站联系: qq:121756557 email:121756557@qq.com  IT数码