免费注册 查看新帖 |

Chinaunix

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

求个算法? [复制链接]

论坛徽章:
0
跳转到指定楼层
1 [收藏(0)] [报告]
发表于 2009-12-30 11:09 |只看该作者 |倒序浏览
有数组(1,2,3,4,5,6,7,8,9,10);
求取其中5个数的所有组合;

[ 本帖最后由 hh9net 于 2009-12-30 11:31 编辑 ]

论坛徽章:
0
2 [报告]
发表于 2009-12-30 11:38 |只看该作者
原帖由 hh9net 于 2009-12-30 11:09 发表
有数组(1,2,3,4,5,6,7,8,9,10);
求取其中5个数的所有组合;


C<.pick> and X in Perl6 ?

[ 本帖最后由 lokchungk 于 2009-12-30 11:43 编辑 ]

论坛徽章:
0
3 [报告]
发表于 2009-12-30 12:14 |只看该作者
算法·····弱项·

论坛徽章:
0
4 [报告]
发表于 2009-12-30 12:59 |只看该作者


  1. use Math::Combinatorics;
  2. print join $/, map { join $", @$_ } combine(5, 1..10);

复制代码

论坛徽章:
0
5 [报告]
发表于 2009-12-30 13:27 |只看该作者
  1. my @agrs=(1..10);
  2. func(0,\@agrs);

  3. sub func{
  4.     my $i=shift;
  5.     my $agrs=shift;
  6.     my @array=@_;
  7.    
  8.     if(scalar(@array)==5){
  9.         print join ' ',@array,"\n";
  10.     }else{
  11.         foreach ($i..$#agrs){
  12.             func(++$i,$agrs,@array,$agrs->[$_]);
  13.         }
  14.     }
  15. }
复制代码

如果顺序没要求的话

论坛徽章:
0
6 [报告]
发表于 2010-01-03 00:03 |只看该作者
给个简洁但低效的方法:


my $i = 0;
"1234567890" =~ m/
    (\d)\d*(\d)\d*(\d)\d*(\d)\d*(\d)
    (?{ printf("%3d: %s%s%s%s%s\n", ++$i, $1, $2, $3, $4, $5); })
    (?!)
/x;
您需要登录后才可以回帖 登录 | 注册

本版积分规则 发表回复

  

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

清除 Cookies - ChinaUnix - Archiver - WAP - TOP