input_list = [(2282.405, -89.9415, 266.1414), (2276.534, -89.9526, 266.9091), (2276.534, -83.9573, 266.9091), (2282.405, -83.9464, 266.1414), (2288.276, -77.9407, 265.3738), (2294.148, -77.9301, 264.6062), (2294.148, -83.9247, 264.6062), (2288.276, -83.9356, 265.3738), (2282.405, -71.9563, 266.1414), (2288.276, -71.9459, 265.3738), (2282.405, -77.9514, 266.1414), (2288.276, -89.9304, 265.3738), (2276.534, -77.962, 266.9091), (2294.148, -71.9355, 264.6062), (2276.534, -71.9667, 266.9091), (2294.148, -89.9193, 264.6062)]
要求列出9个列表,其中包含4个点的坐标,构成一个闭环。

我尝试了一些方法,找到距离,然后创建集合,但问题是点在中间,有4个组合开始。
要求使用python准确地得到9个列表,如图像所示(列表将包含4个网格的坐标)序列应该始终是逆时针方向的。
发布于 2022-11-05 13:44:16
要求得到“逆时针方向”的答案,在3d作业中是很棘手的。一片叶子有两面,但我可以想象,实际的要求是总是在相同的顺序上循环,如果边被计数一次"a到b",下一次它将被计算为"b到a“。另外,您的示例看起来是平面的,并且“网格类似”。如果这是真正的赋值,我建议使用numpy特征向量函数将你的坐标系降到2d,然后一个变换矩阵使你的点对齐到(0,0),(0,1)等等。要找到这个变换矩阵,随机取一个点,在x维上找到最近的一个,y维上最近的一个。我想说你的作业更像是数学作业
编辑:不过,我已经给了它一点。我真的认为最简单的答案是充分利用以下事实:
https://stackoverflow.com/questions/74327545
复制相似问题