我正在寻找一个更简单的解决方案.
我有一个带有相应后缀的前缀列表和一个根列表.
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)
我想,这是可以做到的它更容易使用类似的zip或cross,但无法弄清楚如何?
Eli*_*sen 10
我的解决方案是:
say @roots.map: |(@prefixes >>~>> * <<~<< @postfixes);
Run Code Online (Sandbox Code Playgroud)
为metaopping连接创建一个WhateverCode,滑动结果以获得Seq最后只有标量值的值.
还有几种方法可以编写它:
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)