Perl – 内置功能“拉链”在一起的两个阵列?

前端之家收集整理的这篇文章主要介绍了Perl – 内置功能“拉链”在一起的两个阵列?前端之家小编觉得挺不错的,现在分享给大家,也给大家做个参考。
我想通过从数组A中的第一个元素(数组B的第一个元素)中将两个相等长度的数组合并成一个数组,来自A的第二个元素,B的第二个元素等。以下程序说明了算法:
# file zipper.pl
use strict;
use warnings;
use 5.010;

my @keys   = qw/abel baker charlie dog easy fox/;
my @values = qw/a b c d e f/;

# ==> Is there a builtin function that is equivalent of zipper()? <==
#
my %hash = zipper( \@keys,\@values );

while ( my ( $k,$v ) = each %hash ) {
    say "$k=$v";
}

# zipper(): Take two equal-length arrays and merge them (one from A,one from B,# another from A,another from B,etc.) into a single array.
#
sub zipper {
    my $k_ref = shift;
    my $v_ref = shift;
    die "Arrays must be equal length" if @$k_ref != @$v_ref;
    my $i = 0;
    return map { $k_ref->[ $i++ ],$_ } @$v_ref;
}

产量

$ ./zipper.pl 
easy=e
dog=d
fox=f
charlie=c
baker=b
abel=a

我想知道如果我忽略了Perl中的一个内建函数,这将相当于拉链()。它将在程序的最内层循环,并且需要尽可能快地运行。如果没有内置或CPAN模块,任何人都可以改进我的实现?

解决方法

其他人对网格/拉链方面的问题给出了很好的答案,但是如果您只是从一系列键和一个值创建哈希,您可以使用不赞赏的 hash slice
#!/usr/bin/env perl

use strict;
use warnings;

my @keys   = qw/abel baker charlie dog easy fox/;
my @values = qw/a b c d e f/;

my %hash;
@hash{@keys} = @values;

use Data::Dumper;
print Dumper \%hash;

附录

我想到为什么可以选择一种方法。我个人认为切片实现与zip一样可读,但其他可能不同意。如果你经常这样做,你可能会关心速度,在这种情况下,切片形式更快。

#!/usr/bin/env perl

use strict;
use warnings;

use List::MoreUtils qw/zip/;
use Benchmark qw/cmpthese/;

my @keys   = qw/abel baker charlie dog easy fox/;
my @values = qw/a b c d e f/;

cmpthese( 100000,{
  zip => sub {
    my %hash = zip @keys,@values;
  },slice => sub {
    my %hash;
    @hash{@keys} = @values;
  },});

结果:

Rate   zip slice
zip   51282/s    --  -34%
slice 78125/s   52%    --

猜你在找的Perl相关文章