繁体   English   中英

Perl排序哈希的数组

[英]Perl Sort Hash of Arrays

我有一个如下所示的数组哈希:

{ $key, [$val1, $val2] }

我正在尝试按数值排序数组的第二个值并打印出整个哈希值。 我看过Schwartzian Transform的帖子,但我还没有看到一个完全符合我想要的帖子。 我也对语法以及如何将排序值映射回原始{$key, [$val1, $val2] }表单感到困惑。 任何帮助,将不胜感激!

不太确定你指的是什么,但这是你如何在一个数组值上实现一个排序例程,在一个哈希中:

my %hash = ( 'key1' => [ 1, 2 ], 'key2' => [ 2, 3 ] );

for my $key ( sort { $hash{$a}[1] <=> $hash{$b}[1] } keys %hash ) {
    print "$key => '", join(", ", @{$hash{$key}}), "'\n";
}

我真的想要使用Schwartzian-Transform,这是一种方法:

#!/usr/bin/perl
use Data::Dump qw(dump);

my %hash = (k1 => [1, 2], k2 => [24, 5], k3 => [5, 1]);
foreach(
        sort { $a->[1] <=> $b->[1] }
        map { [$_, $hash{$_}->[1] ] } keys %hash) {
    say $_->[0],' => ',dump$hash{$_->[0]};
}

输出:

k3 => [5, 1]
k1 => [1, 2]
k2 => [24, 5]

注意:

我只是将这个答案作为Schwartzian变换的一个例子

但正如评论中所述,在问题中解释的情况下不需要它,当排序之前对阵列的每个元素进行一些计算时,ST是节省成本的。 对于提出的问题,没有计算要做,所以不要在这里使用ST。

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM