免费注册 查看新帖 |

Chinaunix

  平台 论坛 博客 文库
最近访问板块 发新帖
楼主: marksman201
打印 上一主题 下一主题

shell排序 [复制链接]

论坛徽章:
0
1 [报告]
发表于 2010-09-28 15:22 |显示全部楼层
没明白

论坛徽章:
0
2 [报告]
发表于 2010-09-28 16:34 |显示全部楼层
回复 4# marksman201


    Got it. Try:
  1. awk -F "[: ]+" '{for(i=1;i<NF;i+=2){a[$(i+1)":"$i]=$i":"$(i+1);b[++n]=$(i+1)":"$i};asort(b);for(z=1;z<=n;z++){sum+=b[z];if(sum>0.5){for(k=1;k<z;k++){printf a[b[k]]" "};break}};delete a;delete b;n=sum=0;printf "\n"}' data
复制代码

论坛徽章:
0
3 [报告]
发表于 2010-09-28 16:37 |显示全部楼层
  1. [root@localhost pub]# cat data
  2. a:0.13 b:0.23 c:0.05 d:0.45 e:0.07
  3. p:0.13 q:0.20 r:0.13 s:0.33 t:0.23
  4. h:0.08 g:0.11 r:0.05 y:0.45 s:0.24
  5. [root@localhost pub]# awk -F "[: ]+" '{for(i=1;i<NF;i+=2){a[$(i+1)":"$i]=$i":"$(i+1);b[++n]=$(i+1)":"$i};asort(b);for(z=1;z<=n;z++){sum+=b[z];if(sum>0.5){for(k=1;k<z;k++){printf a[b[k]]" "};break}};delete a;delete b;n=sum=0;printf "\n"}' data
  6. c:0.05 e:0.07 a:0.13 b:0.23
  7. p:0.13 r:0.13 q:0.20
  8. r:0.05 h:0.08 g:0.11 s:0.24
  9. [root@localhost pub]#
复制代码

论坛徽章:
0
4 [报告]
发表于 2010-09-28 16:49 |显示全部楼层
回复 25# blackold


    黑哥理解有误吧呵呵

论坛徽章:
0
5 [报告]
发表于 2010-09-28 16:55 |显示全部楼层
回复 28# blackold


    LZ的本来意思是从每一行的这些项里选择k项,使得这k项的和小于0.5,并且k尽量大。 不是前k项。呵呵

论坛徽章:
0
6 [报告]
发表于 2010-09-28 16:58 |显示全部楼层
回复 34# marksman201


    楼主面试的哪个公司阿?

论坛徽章:
0
7 [报告]
发表于 2010-09-28 17:16 |显示全部楼层
回复 38# 好看的附件
  1. [root@localhost pub]# cat data
  2. a:0.13 b:0.23 c:0.05 d:0.45 e:0.07
  3. p:0.13 q:0.20 r:0.13 s:0.33 t:0.23
  4. h:0.08 g:0.11 r:0.05 y:0.45 s:0.24
  5. g:0.01 q:0.02 r:0.03 s:0.04 t:0.05
  6. g:0.21 q:0.22 r:0.03 s:0.04 t:0.05
  7. [root@localhost pub]# awk -F "[: ]+" '{for(i=1;i<NF;i+=2){a[$(i+1)":"$i]=$i":"$(i+1);b[++n]=$(i+1)":"$i};asort(b);for(z=1;z<=n;z++){sum+=b[z];if(sum>0.5){for(k=1;k<z;k++){printf a[b[k]]" "};break};if(z==n){for(k=1;k<=n;k++){printf a[b[k]]" "}}};delete a;delete b;n=sum=0;printf "\n"}' data
  8. c:0.05 e:0.07 a:0.13 b:0.23
  9. p:0.13 r:0.13 q:0.20
  10. r:0.05 h:0.08 g:0.11 s:0.24
  11. g:0.01 q:0.02 r:0.03 s:0.04 t:0.05
  12. r:0.03 s:0.04 t:0.05 g:0.21
  13. [root@localhost pub]#
复制代码
您需要登录后才可以回帖 登录 | 注册

本版积分规则 发表回复

  

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

清除 Cookies - ChinaUnix - Archiver - WAP - TOP