免费注册 查看新帖 |

Chinaunix

  平台 论坛 博客 文库
最近访问板块 发新帖
查看: 6126 | 回复: 7
打印 上一主题 下一主题

哈希怎么按value排序并取前n个的键值对? [复制链接]

论坛徽章:
0
跳转到指定楼层
1 [收藏(0)] [报告]
发表于 2014-01-13 15:41 |只看该作者 |倒序浏览
RT,哈希%hash,怎么排序并取前n个键值对
$hash{"a"}=1;
$hash{"b"}=2;
$hash{"c"}=21;
$hash{"d"}=4;
$hash{"e"}=13;
$hash{"f"}=12;
前3:
c 21
e 13
f 12

论坛徽章:
8
技术图书徽章
日期:2013-09-30 08:51:28技术图书徽章
日期:2013-12-11 09:26:39白羊座
日期:2013-12-27 15:27:13金牛座
日期:2014-01-06 09:13:05天蝎座
日期:2014-01-21 14:23:28酉鸡
日期:2014-05-09 16:51:12卯兔
日期:2014-08-11 16:49:1515-16赛季CBA联赛之八一
日期:2017-08-14 23:24:57
2 [报告]
发表于 2014-01-13 15:55 |只看该作者
本帖最后由 xiumu2280 于 2014-01-13 15:56 编辑
  1. my %hash = (
  2.         a => 1,
  3.         b => 2,
  4.         c => 21,
  5.         d => 4,
  6.         e => 13,
  7.         f => 12,
  8. );
  9. my @data = sort {$hash{$b} <=> $hash{$a}}keys %hash;
  10. my $n = 2;
  11. print "$_=>$hash{$_}\n" for @data[0..$n];
复制代码
  1. c=>21
  2. e=>13
  3. f=>12
复制代码

论坛徽章:
0
3 [报告]
发表于 2014-01-13 17:07 |只看该作者
本帖最后由 justfaz 于 2014-01-13 17:07 编辑

my @data = sort {$hash{$b} <=> $hash{$a} or  $a cmp $b }keys %hash

帮楼上的完善一下(考虑到值相同的情况)

论坛徽章:
1
未羊
日期:2014-01-02 10:31:18
4 [报告]
发表于 2014-01-13 17:10 |只看该作者
本帖最后由 huzikan 于 2014-01-13 17:19 编辑

  1. #! /usr/bin/perl
  2. @hash{qw/a b c d e f/}=(1,2,21,4,13,12);
  3. for (sort{$hash{$b} <=> $hash{$a}}keys %hash) {
  4.         last if ++$n>3;
  5.         print "$_ $hash{$_}\n";
  6. }
复制代码
命令行模式

  1. perl -e '{@hash{qw/a b c d e f/}=(1,2,21,4,13,12);print map{sprintf "$_ $hash{$_}\n"} (sort{$hash{$b} <=> $hash{$a}}keys %hash)[0..2]}';
复制代码

论坛徽章:
5
丑牛
日期:2014-01-21 08:26:26卯兔
日期:2014-03-11 06:37:43天秤座
日期:2014-03-25 08:52:52寅虎
日期:2014-04-19 11:39:48午马
日期:2014-08-06 03:56:58
5 [报告]
发表于 2014-01-13 20:57 |只看该作者
大概看了一下 写的太好了
{:2_172:} 我心中一种畅快的感觉呀

论坛徽章:
95
程序设计版块每日发帖之星
日期:2015-09-05 06:20:00程序设计版块每日发帖之星
日期:2015-09-17 06:20:00程序设计版块每日发帖之星
日期:2015-09-18 06:20:002015亚冠之阿尔艾因
日期:2015-09-18 10:35:08月度论坛发贴之星
日期:2015-09-30 22:25:002015亚冠之阿尔沙巴布
日期:2015-10-03 08:57:39程序设计版块每日发帖之星
日期:2015-10-05 06:20:00每日论坛发贴之星
日期:2015-10-05 06:20:002015年亚冠纪念徽章
日期:2015-10-06 10:06:482015亚冠之塔什干棉农
日期:2015-10-19 19:43:35程序设计版块每日发帖之星
日期:2015-10-21 06:20:00每日论坛发贴之星
日期:2015-09-14 06:20:00
6 [报告]
发表于 2014-01-13 22:45 |只看该作者
本帖最后由 MMMIX 于 2014-01-13 22:57 编辑

回复 4# huzikan


    这个 for 循环里面的提前退出判断完全可以用 array slice 代替,而且使用 array slice 的话逻辑会更清晰,为嘛在一行式脚本中用了,反倒在更正式的脚本中却不用了?

论坛徽章:
1
未羊
日期:2014-01-02 10:31:18
7 [报告]
发表于 2014-01-14 09:04 |只看该作者
个人理解是命令行模式尽量以简洁作为前提,如果是脚本的话尽量以可读性和易理解性为前提来写,但是同时都应该考虑效率问题。至于为什么写成了这样。。是因为才学了slice的用法想练习一下,有什么说的不对的地方望指点~
回复 6# MMMIX


   

论坛徽章:
95
程序设计版块每日发帖之星
日期:2015-09-05 06:20:00程序设计版块每日发帖之星
日期:2015-09-17 06:20:00程序设计版块每日发帖之星
日期:2015-09-18 06:20:002015亚冠之阿尔艾因
日期:2015-09-18 10:35:08月度论坛发贴之星
日期:2015-09-30 22:25:002015亚冠之阿尔沙巴布
日期:2015-10-03 08:57:39程序设计版块每日发帖之星
日期:2015-10-05 06:20:00每日论坛发贴之星
日期:2015-10-05 06:20:002015年亚冠纪念徽章
日期:2015-10-06 10:06:482015亚冠之塔什干棉农
日期:2015-10-19 19:43:35程序设计版块每日发帖之星
日期:2015-10-21 06:20:00每日论坛发贴之星
日期:2015-09-14 06:20:00
8 [报告]
发表于 2014-01-14 09:14 |只看该作者
huzikan 发表于 2014-01-14 09:04
个人理解是命令行模式尽量以简洁作为前提,如果是脚本的话尽量以可读性和易理解性为前提来写,

这话没错。但是,最影响程序可读性的,往往不是语法,而是逻辑。像提前结束循环之类的用法,在很短的循环体之中倒是没什么影响,但是对于比较复杂的循环体来说,就会增加理解的难度,所以能避免还是避免的好。
您需要登录后才可以回帖 登录 | 注册

本版积分规则 发表回复

  

北京盛拓优讯信息技术有限公司. 版权所有 京ICP备16024965号-6 北京市公安局海淀分局网监中心备案编号:11010802020122 niuxiaotong@pcpop.com 17352615567
未成年举报专区
中国互联网协会会员  联系我们:huangweiwei@itpub.net
感谢所有关心和支持过ChinaUnix的朋友们 转载本站内容请注明原作者名及出处

清除 Cookies - ChinaUnix - Archiver - WAP - TOP