algorithm - 路径跟随算法

标签 algorithm math

假设我有一个看起来像这样的形状:

 __ __
|__|__|

有 7 条线段,每条 2 个单位长。

每条线上的开始和结束段都有一个 (x, y) 坐标。

这些行可能存储在一个数组中,如下所示:

[
    [0, 0,  2, 0],
    [0, 0,  0, 2],
    [0, 2,  2, 2],
    [2, 0,  2, 2],
    [2, 0,  4, 0],
    [2, 2,  4, 2],
    [4, 0,  4, 2]
]

所有这些线都是相连的。如果有其他线路未连接,我如何确定这些特定线路(所有线路)是否已连接。

基本上我想不出任何能得到所有线条的东西。

如果有人能在概念上或代码方面为我指出正确的方向,我们将不胜感激。

最佳答案

朴素的 Perl 版本:

use warnings;
use strict;

my $l = [ [0, 0,  2, 0],
          [0, 0,  0, 2],
          [0, 2,  2, 2],
          [2, 0,  2, 2],
          [2, 0,  4, 0],
          [2, 2,  4, 2],
          [4, 0,  4, 2] ];

my @f;
Segment:
while (my $line = shift @$l) {
        for my $set (@f) {
                push (@$set, $line), next Segment if is_conn($line, $set);
        }
        push @f, [$line];
}

for my $set (@f) {
        print "\n================\n";
        print join(",", @$_), "\n" for @$set;
}

sub is_conn {
        my ($line, $set) = (shift, shift);
        for my $cand (@$set) {
                return 1 if has_same_point($cand, $line);
        }
        return 0;
}

sub has_same_point {
        my ($l1, $l2) = @_;
        my @p11 = ($l1->[0], $l1->[1]);
        my @p12 = ($l1->[2], $l1->[3]);
        my @p21 = ($l2->[0], $l2->[1]);
        my @p22 = ($l2->[2], $l2->[3]);
        return is_same_point(@p11, @p21) ||
               is_same_point(@p12, @p21) ||
               is_same_point(@p11, @p22) ||
               is_same_point(@p12, @p22);
}

sub is_same_point {
        my ($x1, $y1, $x2, $y2) = (@_);
        return $x1 == $x2 && $y1 == $y2;
}

关于algorithm - 路径跟随算法,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/15374930/

相关文章:

algorithm - 找到任何算法难题的时间复杂度的严格下限?

ruby - 如何绘制一个大小为 n 的方形网格到控制台?

algorithm - 为二叉树创建祖先矩阵

algorithm - 给定 n 个独立试验的个体概率,如何准确计算 k 个成功的概率?

c# - 我可以使用什么数学公式来获取给定日期的日期(例如星期五)?

algorithm - 局部算法和贪心算法有什么区别?

algorithm - 如何生成 float 的随机分区并且每个部分都有最小值pMin?

java - Android - 调整可缩放 ImageView 顶部的 ImageView 位置

algorithm - 圆线段碰撞检测算法?

algorithm - 理解为什么 Dijkstra 算法在具有负边的图上失败的解释?