免费注册 查看新帖 |

Chinaunix

  平台 论坛 博客 文库
12
最近访问板块 发新帖
楼主: njuytwc
打印 上一主题 下一主题

如何得到不同原子排列的可能组合方式?要求不重复 [复制链接]

论坛徽章:
2
射手座
日期:2014-10-10 15:59:4715-16赛季CBA联赛之上海
日期:2016-03-03 10:27:14
11 [报告]
发表于 2011-10-03 12:15 |只看该作者
8楼的算法还是有问题的,并没有穷举出来
如:CNNNCNNC
ywlscpl 发表于 2011-10-03 10:06



    的确是有问题,想要awk写个递归穷尽,没成功,还是用perl吧
  1. cat s.pl

  2. #!/bin/perl

  3. use strict;

  4. my $txt="CCCNNNNN";
  5. my @array=split "", $txt;
  6. my %hash;

  7. sub switch{
  8.         my $t;
  9.         my ($a,$b,$c)=@_;
  10.         $t=@$c[$a];
  11.         @$c[$a]=@$c[$b];
  12.         @$c[$b]=$t;
  13. }

  14. sub arrange{
  15.         my $i;
  16.         my ($index,@arr)=@_;
  17.         if($index==8) {
  18.                         my $t=join "", @arr;
  19.                         if(! defined $hash{$t}){
  20.                                 $hash{$t}++;$hash{reverse $t}++;print @arr,"\n";
  21.                         }
  22.         }
  23.         else{
  24.                 for($i=$index;$i<8;$i++){
  25.                         switch($index,$i,\@arr);
  26.                         arrange($index+1,@arr);
  27.                         switch($index,$i,\@arr);
  28.                 }
  29.         }
  30. }

  31. arrange(0,@array);

  32. perl s.pl
  33. CCCNNNNN
  34. CCNCNNNN
  35. CCNNCNNN
  36. CCNNNCNN
  37. CCNNNNCN
  38. CCNNNNNC
  39. CNCCNNNN
  40. CNCNCNNN
  41. CNCNNCNN
  42. CNCNNNCN
  43. CNCNNNNC
  44. CNNCCNNN
  45. CNNCNCNN
  46. CNNCNNCN
  47. CNNCNNNC
  48. CNNNCCNN
  49. CNNNCNCN
  50. CNNNNCCN
  51. NCCCNNNN
  52. NCCNCNNN
  53. NCCNNCNN
  54. NCCNNNCN
  55. NCNCCNNN
  56. NCNCNCNN
  57. NCNCNNCN
  58. NCNNCCNN
  59. NNCCCNNN
  60. NNCCNCNN

复制代码

论坛徽章:
3
2015年辞旧岁徽章
日期:2015-03-03 16:54:152015年迎新春徽章
日期:2015-03-04 09:51:162015年亚洲杯之阿曼
日期:2015-04-07 20:00:59
12 [报告]
发表于 2011-10-03 15:45 |只看该作者
提示: 作者被禁止或删除 内容自动屏蔽

论坛徽章:
0
13 [报告]
发表于 2011-10-05 23:18 |只看该作者
回复 11# yinyuemi
辛苦了,这个是对的,不过如果有x个C和y个N,这个程序可以通用吗?比如2个C,4个N这样的可以排多少?该如何修改s.pl程序呢?

论坛徽章:
0
14 [报告]
发表于 2011-10-05 23:43 |只看该作者
回复 11# yinyuemi


    貌似会修改了,谢谢。不过我想知道你这个程序思想是怎么样的,基于什么原理?
您需要登录后才可以回帖 登录 | 注册

本版积分规则 发表回复

  

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

清除 Cookies - ChinaUnix - Archiver - WAP - TOP