乐筑天下

搜索
欢迎各位开发者和用户入驻本平台 尊重版权,从我做起,拒绝盗版,拒绝倒卖 签到、发布资源、邀请好友注册,可以获得银币 请注意保管好自己的密码,避免账户资金被盗
查看: 94|回复: 5

[求助]平面上点坐标顺时针排序问题

[复制链接]

12

主题

71

帖子

3

银币

初露锋芒

Rank: 3Rank: 3Rank: 3

铜币
119
发表于 2004-5-23 12:18:00 | 显示全部楼层 |阅读模式
平面上有n+1(n为自然数)个点的坐标
定义二维数组如下
Dim vntPts(0 to n,0 to 2)
第一维为点的序号
第二维为点的x,y,z坐标,且z坐标始终为0
请问:如何对这个数组进行排序,使其对应的坐标序列在平面上按照顺时针分布?
回复

使用道具 举报

72

主题

2726

帖子

9

银币

社区元老

Rank: 75Rank: 75Rank: 75

铜币
3014
发表于 2004-5-23 13:01:00 | 显示全部楼层
Values是点到中点的角度数组Points 是点数组
  1. Private Sub SortPoint(ByRef Values As Variant, ByRef Points As Variant, ByVal Count As Integer)
  2. Dim pTemp As Double, pnt As Variant
  3. For i = Count To 1 Step -1
  4.        For j = 0 To i - 1
  5.                If Values(j) > Values(j + 1) Then
  6.                        pTemp = Values(j + 1)
  7.                        Values(j + 1) = Values(j)
  8.                        Values(j) = pTemp
  9.                        pnt = Points(j + 1)
  10.                        Points(j + 1) = Points(j)
  11.                        Points(j) = pnt
  12.                End If
  13.        Next j
  14. Next i
  15. End Sub
回复

使用道具 举报

12

主题

71

帖子

3

银币

初露锋芒

Rank: 3Rank: 3Rank: 3

铜币
119
发表于 2004-5-23 17:32:00 | 显示全部楼层
多谢赐复,感觉上面的方法有一个很重要的条件是要知道"中心"的位置.
还请问这个位置能否通过那些点的坐标算出呢?要不然角度数组也就无从谈起了.
回复

使用道具 举报

72

主题

2726

帖子

9

银币

社区元老

Rank: 75Rank: 75Rank: 75

铜币
3014
发表于 2004-5-23 17:45:00 | 显示全部楼层
应该可以通过各点的XY轴坐标的算术平均值求得吧
回复

使用道具 举报

12

主题

71

帖子

3

银币

初露锋芒

Rank: 3Rank: 3Rank: 3

铜币
119
发表于 2004-5-23 18:04:00 | 显示全部楼层
多谢,偶去试试!
回复

使用道具 举报

25

主题

77

帖子

3

银币

初露锋芒

Rank: 3Rank: 3Rank: 3

铜币
177
发表于 2007-1-10 16:36:00 | 显示全部楼层
这个是不是对所有的形状的坐标有效呀?
回复

使用道具 举报

发表回复

您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

  • 微信公众平台

  • 扫描访问手机版

  • 点击图片下载手机App

QQ|关于我们|小黑屋|乐筑天下 繁体中文

GMT+8, 2025-7-7 05:51 , Processed in 1.181318 second(s), 64 queries .

© 2020-2025 乐筑天下

联系客服 关注微信 帮助中心 下载APP 返回顶部 返回列表