我有一个数组哈希,我想按数组大小对它们进行排序。
到目前为止,这是我的代码:
use strict;
use warnings;
my %hash_array = (
"array_1" => ["apple", "ball", "cat"],
"array_2" => ["def", "leppard", "rocks", "too"],
"array_3" => ["italian", "pastry", "missing", "cherry", "top"],
);
# Length of array_1
my $array_1_size = @{$hash_array{"array_1"}};
print "Should print three: $array_1_size\n";
# Found this here: https://stackoverflow.com/questions/15722286
# But my result remains unsorted
foreach my $key ( sort { $hash_array{$b} <=> $hash_array{$a}} keys %hash_array ) {
print "key: $key\n";
}
我了解如何获取单个数组的大小,但我不确定如何将其与排序函数结合使用。
我从这里复制了最后一个 foreach 块,但该解决方案对我不起作用,因为我的输出没有排序。我对最后一段代码有一些疑问:
- 我没有看到前面提到的 $b 和 $a。这是排序函数理解的内置参考吗?
- 该解决方案似乎适用于原始海报,但不适用于我的情况。然而,我们最初的目标是相似的。为了获得基于数组大小的有序输出,我缺少什么?
- 按数组大小按升序和降序对数组散列进行排序的最佳方法是什么?