scala实现 二维点集排序

算法思想
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.csdn.net/csxiaoshui/article/details/73498340?utm_source=copy

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值