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