明经CAD社区

 找回密码
 注册

QQ登录

只需一步,快速开始

搜索
查看: 1761|回复: 5

有一算法问题请大伙帮忙

[复制链接]
发表于 2003-12-8 21:33:00 | 显示全部楼层 |阅读模式
问题:
假设平面中有若干点,有何办法创建一多义线,使其首尾相连,且不交叉?
发表于 2003-12-8 21:52:00 | 显示全部楼层
这个算法就大了,将所有点存入一个数组,假设为N点。任意取出一点为起点,接下来第一段的终点就有N-1种,而第二段的终点就有N-2种,……,总共有N(N-1)(N-2)……1,从第三段开始还要与前面的各段进行比较,判断有没有交叉。
呵呵,这个解决了,那呼吸的世界中那一道关于连线的问题也解决了。
发表于 2003-12-8 23:48:00 | 显示全部楼层
比“呼吸的世界中那一道关于连线的问题”易多了,在这里,任意加入一点,一定可以找到一个合适的插入位置。“呼吸的世界中那一道关于连线的问题”,每一个节点,最多只有四个方向啊:(
发表于 2003-12-9 08:06:00 | 显示全部楼层
哦~~~有意思~~~
发表于 2003-12-10 10:10:00 | 显示全部楼层
我觉得这样也行啊:将所有点存入一个数组,然后以X(或Y)为基准,给定一个增量,然后在Y(或X)方向检索数组,按其大小依次排列数组。最后绘出来的类似于M行
发表于 2003-12-12 08:26:00 | 显示全部楼层
如果点阵的总数不多时,采用穷举的方法还可以勉强接受,但如果数量太多时,这种方法就难以忍受.因为在经过N次尝试连接成功,前面的N-1次尝试都是失败的,而每次尝试一般都要经过庞大的计算量.
可以用这种算法:类似于雷达扫描的方法即旋转扫描的方法.
1 在点阵的外围找到一个初始点.
2 给定一个初始角
3 沿初始角按一个确定的方法(顺时针/逆时针)旋转
4 扫描到的第一个点就是下一个基点,并连接这两个点,以此类推.
5 如果扫描到的后续点是初始点,那么就改变扫描的方法,以此类推.
6 如果已经没有未扫描的点,就连接初始点.
这种方法的优点是:可以确保每一次连接都是正确的,而没有N-1次的失败.
您需要登录后才可以回帖 登录 | 注册

本版积分规则

小黑屋|手机版|CAD论坛|CAD教程|CAD下载|联系我们|关于明经|明经通道 ( 粤ICP备05003914号 )  
©2000-2023 明经通道 版权所有 本站代码,在未取得本站及作者授权的情况下,不得用于商业用途

GMT+8, 2024-11-28 12:43 , Processed in 0.168130 second(s), 23 queries , Gzip On.

Powered by Discuz! X3.4

Copyright © 2001-2021, Tencent Cloud.

快速回复 返回顶部 返回列表