在Perl 6中连接列表

Eug*_*sky 7 perl6

我正在寻找一个更简单的解决方案.

我有一个带有相应后缀的前缀列表和一个根列表.

my @prefixes = 'A'..'E';
my @suffixes = 'a'..'e';
my @roots = 1, 2;
Run Code Online (Sandbox Code Playgroud)

我想提出的所有可能的话": A1a,B1b... A2a... E2e.

my @words;
for @roots -> $r {
    for @prefixes.kv -> $i, $p {
        my $s = @suffixes[$i];
        my $word = [~] $p, $r, $s;
        @words.push: $word;
    }
}
say @words; # [A1a B1b C1c D1d E1e A2a B2b C2c D2d E2e]
Run Code Online (Sandbox Code Playgroud)

我想,这是可以做到的它更容易使用类似的zipcross,但无法弄清楚如何?

Eli*_*sen 10

我的解决方案是:

say @roots.map: |(@prefixes >>~>> * <<~<< @postfixes);
Run Code Online (Sandbox Code Playgroud)

为metaopping连接创建一个WhateverCode,滑动结果以获得Seq最后只有标量值的值.


sml*_*mls 8

还有几种方法可以编写它:


say @roots X[&join] (@prefixes Z @suffixes);
Run Code Online (Sandbox Code Playgroud)
say @roots.map({ |(@prefixes Z @suffixes)».join($_) });
Run Code Online (Sandbox Code Playgroud)
say @roots.map({ (@prefixes X~ $_) Z~ @suffixes }).flat;
Run Code Online (Sandbox Code Playgroud)
say (|@prefixes xx *) Z~ (@roots X~ @suffixes);
Run Code Online (Sandbox Code Playgroud)
my @formats = (@prefixes Z @suffixes).flat.map(* ~ '%s' ~ *);
say @formats X[&sprintf] @roots;
Run Code Online (Sandbox Code Playgroud)

(注意:这个以不同的顺序打印它们.)


say do for @roots -> $root {
    |do for (@prefixes Z @suffixes) -> [$prefix, $suffix] {
        $prefix ~ $root ~ $suffix
    }
}
Run Code Online (Sandbox Code Playgroud)