scala实现 二维点集排序

本文介绍了一种用于凸多边形点排序的算法,通过计算多边形的重心并将其作为参照向量,然后计算各顶点与重心构成向量与参照向量的夹角,最终根据夹角大小对顶点进行排序。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

算法思想
1.首先计算出凸多边形的重心点
2.构建原点到重心点的向量,作为参照向量
3.分别计算重心点和各个定点组成的向量与参照向量之间的夹角
4.根据夹角大小进行排序
二维点集排序

def tdimSort(plist: List[Point]) = {
    //求多边形的重心
    val orthocenter = Point(plist.map(_.x).sum / plist.size, plist.map(_.y).sum / plist.size)
    val x = orthocenter.x
    val y = orthocenter.y
    // 计算从v1到v2的夹角公式
    // θ=atan2(v1.y,v1.x)−atan2(v2.y,v2.x)
    val voatan2 = atan2(y, x)
    plist.map(p => {
      // 计算向量夹角
      val theta: Double = voatan2 - atan2(p.y - y, p.x - x)
      (p, theta)
    })
      .sortBy(_._2).map(_._1) // 根据角度排序(顺逆时针都可以)
  }

 // 构造点集
 val list = List(Point(0, 0), Point(4, 0), Point(0, 4), Point(-4, 2), Point(6, 2), Point(4, 4), Point(-6, 0))
 // 方法调用
 tdimSort(list).foreach(println)

输出结果

Point(-4.0,2.0)
Point(0.0,4.0)
Point(4.0,4.0)
Point(6.0,2.0)
Point(4.0,0.0)
Point(0.0,0.0)
Point(-6.0,0.0)

如有不当之处,欢迎指正

参考资料

https://blog.youkuaiyun.com/csxiaoshui/article/details/73498340?utm_source=copy

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值