免费注册 查看新帖 |

Chinaunix

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

perl算法请教 [复制链接]

论坛徽章:
0
跳转到指定楼层
1 [收藏(0)] [报告]
发表于 2012-12-20 09:59 |只看该作者 |倒序浏览
现有文件如下格式:

aaa  1 (1~2)
bbb  2  (2~5)
ccc  6  (4~
...

一共有多少行是不定的,需要根据这一份文件产生 n 份文件,当aaa bbb ccc 是变量,括号中(1~2) (2~5)  (4~6) 是变量的范围,产生的文件赋值有排列组合的效果,想得头都大了就是想不出来啊
产生的文件如下:

第一份文件:
aaa 1
bbb 2
ccc 4
.....

第二份文件:
aaa 2
bbb 2
ccc 4
....

第三份文件:
aaa 1
bbb 3
ccc 4
...

第四份文件:
aaa 2
bbb 3
ccc 4
.....

论坛徽章:
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
2 [报告]
发表于 2012-12-20 10:50 |只看该作者
没明白是说什么意思,第一份文件就包含你说那3个变量的所有排列组合?
aaa1
bbb2
ccc4
aaa1
bbb2
ccc5
aaa1
bbb2
ccc6
aaa1
bbb3
ccc4
aaa1
bbb3
ccc5
aaa1
bbb3
ccc6
aaa1
bbb4
ccc4
aaa1
bbb4
ccc5
aaa1
bbb4
ccc6
aaa1
bbb5
ccc4
aaa1
bbb5
ccc5
aaa1
bbb5
ccc6
aaa2
bbb2
ccc4
aaa2
bbb2
ccc5
aaa2
bbb2
ccc6
aaa2
bbb3
ccc4
aaa2
bbb3
ccc5
aaa2
bbb3
ccc6
aaa2
bbb4
ccc4
aaa2
bbb4
ccc5
aaa2
bbb4
ccc6
aaa2
bbb5
ccc4
aaa2
bbb5
ccc5
aaa2
bbb5
ccc6
回复 1# dark_tom


   

论坛徽章:
0
3 [报告]
发表于 2012-12-20 11:32 |只看该作者
每一份文件是一种组合,n份文件就是n个组合

论坛徽章:
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
4 [报告]
发表于 2012-12-20 11:44 |只看该作者
本帖最后由 只是一个红薯 于 2012-12-20 11:45 编辑
  1. #!user/bin/perl
  2. use v5.016;
  3. use Modern::Perl;
  4. my $i=1;
  5. foreach my $aaa(glob'{aaa}{1,2}'){
  6.     foreach my $bbb(glob'{bbb}{2,3,4,5}'){
  7.         foreach my $ccc(glob'{ccc}{4,5,6}'){
  8.             my $out= "$aaa"."\n"."$bbb"."\n"."$ccc\n";
  9.             my $file=$i++;
  10.             open FH,'>>',"$file.txt";
  11.             print FH $out;  
  12.         }
  13.     }
  14. }#不知道行不?这样写有问题的话,请指教。
复制代码
回复 3# dark_tom


   

论坛徽章:
0
5 [报告]
发表于 2012-12-20 12:35 |只看该作者
只是一个红薯 发表于 2012-12-20 11:44
回复 3# dark_tom


如果有100个参数,那岂不是有100个foreach 循环?
而且参数的个数是不定的。

刚在CSDN那边悬赏拿到了答案,用递归算法。

不过还是谢谢你的帮助!

论坛徽章:
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
6 [报告]
发表于 2012-12-20 13:22 |只看该作者
能贴下代码么,看怎么实现的?
dark_tom 发表于 2012-12-20 12:35
如果有100个参数,那岂不是有100个foreach 循环?
而且参数的个数是不定的。

论坛徽章:
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
7 [报告]
发表于 2012-12-20 16:38 |只看该作者
本帖最后由 rubyish 于 2012-12-20 12:53 编辑

想得头都大了
  1. #!/usr/bin/perl

  2. my ( $f, $i, $g ) = ( 'file', 1 );
  3. while (<DATA>) {
  4.     /(\w+).*\((\w+)~(\w+)/;
  5.     $g .= '{' . join( '|,', map "$1@" . $_, $2 .. $3 ) . '|}';
  6. }

  7. for ( glob $g ) {
  8.     s/\|/\n/g;
  9.     s/@/ /g;
  10.     open my $fh, '>', $f . $i++;
  11.     print $fh $_;
  12. }
  13. __DATA__
  14. aaa  1 (1~2)
  15. bbb  2  (2~5)
  16. ccc  6  (4~6)
复制代码
您需要登录后才可以回帖 登录 | 注册

本版积分规则 发表回复

  

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

清除 Cookies - ChinaUnix - Archiver - WAP - TOP