首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >维护中心点周围的点列表,保留CCW顺序

维护中心点周围的点列表,保留CCW顺序
EN

Stack Overflow用户
提问于 2012-02-18 07:04:53
回答 1查看 192关注 0票数 0

我有以下类:

代码语言:javascript
复制
 public class Vertex() {
    private double xCoord;
    private double yCoord;
    private ArrayList<Vertex> neighborList();
 }

我想要支持向neighborList添加/删除顶点,这样这些点就会按CCW顺序排列在这个顶点周围(列表中的第一个点无关紧要)。如果点是共线的,则离此较近的点应该是第一个。我已经尝试了几种方法,但到目前为止,我总是能够找到一个对给定方法无效的反例。

有没有人知道如何以一种简单有效的方式做到这一点?

EN

回答 1

Stack Overflow用户

回答已采纳

发布于 2012-02-18 07:56:28

以极坐标形式表示点坐标

代码语言:javascript
复制
t = atan2(Y-Yo, X-Xo)
r = sqrt((X-Xo)^2 + (Y-Yo)^2)

并在角度上使用字典序排序,然后对半径进行排序。

票数 3
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/9336682

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档