免费注册 查看新帖 |

Chinaunix

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

本人Perl写的有关排列的算法_permutation [复制链接]

论坛徽章:
0
跳转到指定楼层
1 [收藏(0)] [报告]
发表于 2014-05-23 15:22 |只看该作者 |倒序浏览
本帖最后由 tlqtangok 于 2014-05-23 16:02 编辑

排列组合,是一系列的问题,很多书本上都有提及。本代码是原创作品,转载请写明转自tlqtangok 的ChinaUnix
希望大家不吝拍砖,讨论切磋,以挖掘一下最好的算法。
“stdout>>


876541203
876541230
876541302
876541320
876542013
876542031
876542103
876542130
876542301
876542310
876543012
876543021
876543102
876543120
876543201
876543210
:::
:::

> cat _perl.PL

#---souce code ---
###-Usage-:  perl _perl.PL 2>/dev/null ###
#!perl
use feature qw(say);
### CONFIG AREA ###
my $MAX = 8;   # permutation num ;
####### END #######
my @a=qw();
my $len_a=$MAX*2-1;
my $file_header='
#!perl
use feature qw(say);
#--- TEST ---
my $loc_i=0;
my $MAX='."$MAX".'; # the num you want to make the
my @arr_loc=qw();
#---start permutation
';
my $for_header='for(@arr_loc[$loc_i]=0;@arr_loc[$loc_i]<$MAX; @arr_loc[$loc_i]++){      next if $arr_loc[$loc_i] ~~ @arr_loc[0..$loc_i-1];       $loc_i++;       #---;
'x ($MAX-1);
my $say_kernel='     for(@arr_loc[$loc_i]=0;@arr_loc[$loc_i]<$MAX; @arr_loc[$loc_i]++){ next if $arr_loc[$loc_i] ~~ @arr_loc[0..$loc_i-1]; say @arr_loc ;  }#end
' ;
my $for_tail='$loc_i--;      }    #end for
' x ($MAX-1) ;

open FP, '>', "bak.perl.PL";
select FP;
say "$file_header","$for_header\n","$say_kernel\n","$for_tail";
close FP;
select STDOUT;
my @perl_cml=qw(perl bak.perl.PL);
open STDERR, ">",'/dev/null';
system(@perl_cml);
close STDERR;
`rm bak.perl.PL`;

#---END source code ---
本算法是基于一个简单的原理:
for(i=0;i<MAX;i++){
for( j=0;j<MAX;j++){
j !=i;
   for(k=0;k<MAX;k++){
k!=j; k!=i;
then ...
...
}
}
}

这个算法之所以敢贴出来,是因为它的可配置(可以任意设置排列数的个数);
如果你也有这类“珍宝”,拿出来秀一下吧?! 




论坛徽章:
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-05-23 15:26 |只看该作者
看不到,又舍不得分怎么办···

论坛徽章:
0
3 [报告]
发表于 2014-05-23 15:29 |只看该作者
OK,我还是公开算了!我想知道大家对于排列有没有兴趣?回复 2# xiumu2280


   

论坛徽章:
0
4 [报告]
发表于 2014-05-23 16:01 |只看该作者
不知道大家有没有针对排列的好一点的实现? 
您需要登录后才可以回帖 登录 | 注册

本版积分规则 发表回复

  

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

清除 Cookies - ChinaUnix - Archiver - WAP - TOP