凸包算法

本文介绍了凸包问题的概念,通过极角排序和左转判定来理解算法。具体阐述了Graham算法的步骤:选取最下左点,计算角度和距离排序,判断直线并遍历点集,根据左转条件决定是否加入凸包。同时提供了一个实现Graham算法的代码模板。
摘要由CSDN通过智能技术生成

   其实这个算法是在一年前得某场比赛中临时抱佛脚学的,今天重新的来温习了一遍

如何来理解凸包?一组平面上的点,求一个包含所有点的最小的凸多边形,这就是凸包问题了。这可以形象地想成这样:在地上放置一些不可移动的木桩,用一根绳子把他们尽量紧地圈起来,这就是凸包了,百度百科中的这张图很生动+活泼+形象,所以你懂的

好说完这个我们首先要来了解下极角排序和左转判定

极角排序:就是选取一个最左的点,按y最小,其次x最小来定义,接下来所有的点针对该点的射线,

               按角度由小到大,若相同按距离由近到远来排序

左转判定:这个和叉积有关,对于向量p1(x1,y1),p2(x2,y2)如果x1*y2-x2*y1>0,则从p1到p2左转

 

我学的是Graham算法,那么接下来来介绍下该算法

(1)选取最下左的点P0

(2)计算出每个点相对于P0的角度和距离(利用这个来排序)排序

(3)设点数为n,将p[n-1]和p[0]入栈,判断点集合是否为一条直线(初始k=2表示当前凸包的大小)

(4)i从1到n-1遍历,对于p[k-1],p[k-2],p[i]若满足左转,将p[i]压入栈

        否则i--,k--

(5)k--,返回k

  • 0
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值