免费注册 查看新帖 |

Chinaunix

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

请大牛指导多数组内容排列 写成 generator [复制链接]

论坛徽章:
7
戌狗
日期:2013-12-15 20:43:38技术图书徽章
日期:2014-03-05 01:33:12技术图书徽章
日期:2014-03-15 20:31:17未羊
日期:2014-03-25 23:48:20丑牛
日期:2014-04-07 22:37:44巳蛇
日期:2014-04-11 21:58:0915-16赛季CBA联赛之青岛
日期:2016-03-17 20:36:13
跳转到指定楼层
1 [收藏(0)] [报告]
发表于 2013-06-13 15:37 |只看该作者 |倒序浏览
本帖最后由 rubyish 于 2013-06-13 11:39 编辑

my @A = ( [ 'A' .. 'B' ], [ 1 .. 2 ], [ 'a', 'b' ] );

result:
  1. A 1 a
  2. A 1 b
  3. A 2 a
  4. A 2 b
  5. B 1 a
  6. B 1 b
  7. B 2 a
  8. B 2 b
复制代码
zhlong8版主说了 :
  1. 但是由于这个结果数是指数增长的,所以数目比较大时写成 generator 更好
复制代码


请大牛指导写个generator

论坛徽章:
46
15-16赛季CBA联赛之四川
日期:2018-03-27 11:59:132015年亚洲杯之沙特阿拉伯
日期:2015-04-11 17:31:45天蝎座
日期:2015-03-25 16:56:49双鱼座
日期:2015-03-25 16:56:30摩羯座
日期:2015-03-25 16:56:09巳蛇
日期:2015-03-25 16:55:30卯兔
日期:2015-03-25 16:54:29子鼠
日期:2015-03-25 16:53:59申猴
日期:2015-03-25 16:53:29寅虎
日期:2015-03-25 16:52:29羊年新春福章
日期:2015-03-25 16:51:212015亚冠之布里斯班狮吼
日期:2015-07-13 10:44:56
2 [报告]
发表于 2013-06-13 22:59 |只看该作者
use strict;
use warnings;

package Perm;

sub new {
    my $class = shift;
    my $prod = 1;
    $prod *= @$_ for @_;
    bless {
        data => [@_],
        idx  => -1,
        size => [map scalar @$_, @_],
        max  => $prod,
    }, $class;
}

sub _next {
    my $self = shift;
    $self->{idx}++;
    return 0 if $self->{idx} >= $self->{max};
    my @idx  = _select($self->{size}, $self->{idx});
    my $data = $self->{data};
    [map $data->[$_]->[$idx[$_]], 0 .. $#idx];
}

sub _select {
    my($size, $idx) = @_;
    my @result;
    for (reverse @$size) {
        push @result, $idx % $_;
        $idx = int($idx / $_);
    }
    return reverse @result;
}

package main;

my $t = Perm->new(['a3', 'jj', 'm@', 'cc'], ['===>'], [1, 2 ,3, 4], [qw/@  $ %/]);
while ($_ = $t->_next) {
    print "@$_\n";
}

论坛徽章:
0
3 [报告]
发表于 2013-06-13 23:32 |只看该作者
赞啊{:3_190:}

论坛徽章:
3
CU十二周年纪念徽章
日期:2013-10-24 15:41:34子鼠
日期:2013-12-14 14:57:19射手座
日期:2014-04-25 21:23:23
4 [报告]
发表于 2013-06-14 00:47 |只看该作者
老大出面 就是不一样{:3_186:}{:3_186:}{:3_186:}

论坛徽章:
7
戌狗
日期:2013-12-15 20:43:38技术图书徽章
日期:2014-03-05 01:33:12技术图书徽章
日期:2014-03-15 20:31:17未羊
日期:2014-03-25 23:48:20丑牛
日期:2014-04-07 22:37:44巳蛇
日期:2014-04-11 21:58:0915-16赛季CBA联赛之青岛
日期:2016-03-17 20:36:13
5 [报告]
发表于 2013-06-14 01:02 |只看该作者
~ {:3_188:} {:3_188:} {:3_188:}

论坛徽章:
7
戌狗
日期:2013-12-15 20:43:38技术图书徽章
日期:2014-03-05 01:33:12技术图书徽章
日期:2014-03-15 20:31:17未羊
日期:2014-03-25 23:48:20丑牛
日期:2014-04-07 22:37:44巳蛇
日期:2014-04-11 21:58:0915-16赛季CBA联赛之青岛
日期:2016-03-17 20:36:13
6 [报告]
发表于 2013-06-14 01:14 |只看该作者
简而言之,版主 very 强大
3Q
~

求职 : 软件工程师
论坛徽章:
3
程序设计版块每日发帖之星
日期:2015-10-07 06:20:00程序设计版块每日发帖之星
日期:2015-12-13 06:20:00程序设计版块每日发帖之星
日期:2016-05-05 06:20:00
7 [报告]
发表于 2013-06-14 15:31 |只看该作者
  1. #!perl

  2. use 5.010;
  3. use YAML qw(Dump);

  4. my @A = ( [ 'A' .. 'B' ], [ 1 .. 2 ], [ 'a', 'b' ] );

  5. say Dump(generator(@A));

  6. sub _combin {
  7.   my ($array1, $array2) = @_;
  8.   my @array = ();
  9.   foreach my $i (@{$array1}) {
  10.     foreach my $j (@{$array2}) {
  11.       push @array, "$i $j";
  12.     }
  13.   }
  14.   return [@array];
  15. }

  16. sub generator {
  17.   my @array = @_;
  18.   my $first_array = shift @array;
  19.   foreach my $key (@array) {
  20.     $first_array = _combin($first_array, $key);
  21.   }
  22.   return $first_array;
  23. }
复制代码

论坛徽章:
6
卯兔
日期:2013-11-26 14:52:02丑牛
日期:2014-02-19 18:01:25卯兔
日期:2014-05-20 20:34:06白羊座
日期:2014-05-23 13:39:232015亚冠之大阪钢巴
日期:2015-08-07 20:57:582015亚冠之大阪钢巴
日期:2015-09-02 14:09:09
8 [报告]
发表于 2013-06-14 16:37 |只看该作者
厉害

论坛徽章:
7
戌狗
日期:2013-12-15 20:43:38技术图书徽章
日期:2014-03-05 01:33:12技术图书徽章
日期:2014-03-15 20:31:17未羊
日期:2014-03-25 23:48:20丑牛
日期:2014-04-07 22:37:44巳蛇
日期:2014-04-11 21:58:0915-16赛季CBA联赛之青岛
日期:2016-03-17 20:36:13
9 [报告]
发表于 2013-06-14 17:17 |只看该作者
104359176 发表于 2013-06-14 11:31
大牛啊~

论坛徽章:
78
双子座
日期:2013-10-15 08:50:09天秤座
日期:2013-10-16 18:02:08白羊座
日期:2013-10-18 13:35:33天蝎座
日期:2013-10-18 13:37:06狮子座
日期:2013-10-18 13:40:31双子座
日期:2013-10-22 13:58:42戌狗
日期:2013-10-22 18:50:04CU十二周年纪念徽章
日期:2013-10-24 15:41:34巨蟹座
日期:2013-10-24 17:14:56处女座
日期:2013-10-24 17:15:30双子座
日期:2013-10-25 13:49:39午马
日期:2013-10-28 15:02:15
10 [报告]
发表于 2013-06-14 18:01 |只看该作者
代码很漂亮,纯粹的perl风格
您需要登录后才可以回帖 登录 | 注册

本版积分规则 发表回复

  

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

清除 Cookies - ChinaUnix - Archiver - WAP - TOP