首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >路径跟踪算法

路径跟踪算法
EN

Stack Overflow用户
提问于 2013-03-13 08:34:15
回答 1查看 545关注 0票数 1

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

代码语言:javascript
复制
 __ __
|__|__|

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

每条线的起点和终点都有一个(x,y)坐标。

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

代码语言:javascript
复制
[
    [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]
]

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

基本上,我找不出任何东西来得到所有的行。

如果有人能给我指出正确的方向,无论是在概念上还是代码上,那将是非常感谢的。

EN

回答 1

Stack Overflow用户

回答已采纳

发布于 2013-03-30 15:06:29

一个朴素的Perl版本:

代码语言:javascript
复制
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;
}
票数 0
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/15374930

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档