免费注册 查看新帖 |

Chinaunix

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

数组需求突变,求高手快速处理以下数组问题 [复制链接]

论坛徽章:
0
跳转到指定楼层
1 [收藏(0)] [报告]
发表于 2011-09-08 15:47 |只看该作者 |倒序浏览
有一数组 @a 内有10W数据,现有以下要求
1. 删除所有为零的数据
2. 删除前、后各25%的数据,仅保留中间50%的数据

请问如何快速处理呀?

论坛徽章:
0
2 [报告]
发表于 2011-09-08 15:52 |只看该作者
有一数组 @a 内有10W数据,现有以下要求
1. 删除所有为零的数据
2. 删除前、后各25%的数据,仅保留中间50 ...
ztj2247 发表于 2011-09-08 15:47



    掰手指头数。

论坛徽章:
0
3 [报告]
发表于 2011-09-08 15:56 |只看该作者
掰手指头数。
兰花仙子 发表于 2011-09-08 15:52



    没有更快速的方法吗? 求时间复杂度最少的方法

论坛徽章:
0
4 [报告]
发表于 2011-09-08 16:03 |只看该作者
A couple of questions -

1. What kind of data in the array?
2. How much memory do you have on the server planned to run the script?
3. You may want to consider mapreducer if you have a really huge data set.

Thanks

论坛徽章:
0
5 [报告]
发表于 2011-09-08 16:06 |只看该作者
没有更快速的方法吗? 求时间复杂度最少的方法
ztj2247 发表于 2011-09-08 15:56



    这种问题你先求自己实现下吧,实现了再求最优。
最简单用个for循环也会吧。。

$ perl -le '@x=(1,2,3,4,0,1,2,3);for ($i=0;$i<=$#x;$i++){next if $i<2 or $i>5 or !$x[$i];print $x[$i]}'
3
4
1

论坛徽章:
0
6 [报告]
发表于 2011-09-08 16:09 |只看该作者
A couple of questions -

1. What kind of data in the array?
2. How much memory do you have on the ...
zzmmgjj 发表于 2011-09-08 16:03



    1.全是数字
    2. 64G内存,8核CPU
    3. 只想本地计算,不想使用hadoop

论坛徽章:
0
7 [报告]
发表于 2011-09-08 16:10 |只看该作者
1. 清空:@a = ();

2. 先清掉后面的25%,$#a -= 2500;
    再反向 reverse (@a);
    再清25%, $#a -= 2500;
    再恢复回来 reverse (@a);

可能有点复杂,但应该能实现

论坛徽章:
0
8 [报告]
发表于 2011-09-08 16:18 |只看该作者
本帖最后由 Perlvim 于 2011-09-08 16:24 编辑

  1. use strict;
  2. use warnings;
  3. use 5.010;

  4. my @array = (1 .. 100000);
  5. # 获取不为零的部分
  6. my @no_zero_array = grep { $_ != 0 } @array;

  7. my $count = scalar @array;
  8. my $start_number = int(0.25 * $count);
  9. my $end_number = int(0.75 * $count);
  10. my $length = $end_number - $start_number;
  11. # 获取25%--75%的部分
  12. my @splice_array = splice(@array, $start_number, $length);

复制代码

论坛徽章:
0
9 [报告]
发表于 2011-09-08 16:45 |只看该作者
Perlvim 发表于 2011-09-08 16:18



    谢谢,逻辑很清晰 。目前就先采用你的方法吧

论坛徽章:
0
10 [报告]
发表于 2011-09-08 17:02 |只看该作者
没有更快速的方法吗? 求时间复杂度最少的方法
ztj2247 发表于 2011-09-08 15:56



    {:3_203:} 再加上脚趾头。。。
您需要登录后才可以回帖 登录 | 注册

本版积分规则 发表回复

  

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

清除 Cookies - ChinaUnix - Archiver - WAP - TOP