QQ登录

只需要一步,快速开始

 注册地址  找回密码
查看: 4969|回复: 8
打印 上一主题 下一主题

输出一组数字的所有排列

[复制链接]
字体大小: 正常 放大
kampoo        

85

主题

2

听众

400

积分

升级  33.33%

该用户从未签到

新人进步奖

跳转到指定楼层
1#
发表于 2005-12-29 14:29 |只看该作者 |倒序浏览
|招呼Ta 关注Ta
输出一组数字的所有排列,最简单的算法是什么?
zan
转播转播0 分享淘帖0 分享分享0 收藏收藏0 支持支持0 反对反对0 微信微信
fewrains        

0

主题

2

听众

27

积分

升级  23.16%

该用户从未签到

新人进步奖

<>递归,从VChelp的算法版主那里抄来的:</P>
# i& p8 m1 n- i5 o5 `9 Y<><BR>#define  N_permutation 5 // 排列元素数量</P>
/ @, N* J2 m8 O' u: s. D$ i<>unsigned char flag[N_permutation]; // 标记元素是否被使用<BR>unsigned char dat[N_permutation];  // 记录临时元素队列<BR>unsigned char p_dat=0;             // 对列指针</P>4 r1 g* e* ^+ q6 i
<>void out_dat()   // 输出对列dat中的内容<BR>{<BR> for(int i=0;i&lt;N_permutation;i++)<BR>  cout&lt;&lt;dat&lt;&lt;' ';<BR> cout&lt;&lt;endl;<BR>}</P>
4 Z9 H0 Y* b* D+ {# h/ o) o6 I<>void permutation()          // 再入函数,生成N_permutation个字母的所有排列,<BR>{                           // 最大递归次数为N_permutation<BR> unsigned char i;           // 被再入函数入栈保护的局部变量<BR> for(i=0;i&lt;N_permutation;i++) <BR> {<BR>  if (flag==0)<BR>  {<BR>   flag=1;                // 标记元素被使用<BR>   dat[p_dat]=0x41+i;        // 将字母添加到队列<BR>   p_dat++;                  </P>5 ^& F" L2 E6 l4 i
<>   if (p_dat==N_permutation) // 对列满输出,<BR>    out_dat();<BR>   else permutation();       // 否则继续添加<BR>   p_dat--;<BR>   flag=0;<BR>  }<BR> } <BR>}<BR>void main()<BR>{<BR> permutation();<BR> getch();<BR>}</P>[em07][em07][em07]
回复

使用道具 举报

fewrains        

0

主题

2

听众

27

积分

升级  23.16%

该用户从未签到

新人进步奖

<>前头要加上:</P>, K7 w- ]2 d8 q) m3 W. [
<>#include &lt;iostream&gt;<BR>#include &lt;conio.h&gt;<BR>using namespace std;<BR></P>
回复

使用道具 举报

fewrains        

0

主题

2

听众

27

积分

升级  23.16%

该用户从未签到

新人进步奖

<>非递归实现,效率不错</P>. Q6 V' J* n# j3 E$ E7 b
<>#include &lt;iostream&gt;<BR>#include &lt;conio.h&gt;<BR>#include &lt;windows.h&gt;<BR>using namespace std;</P>" U4 W5 R7 _& D
<>void output(int *p);     //输出函数<BR>void permutation(int *p);//全排列函数</P>
# O4 E3 y  Y9 Y# W: ?<>int a[]={1,2,3,4,5,6,7,8,9,10,11};//待排列数组<BR>int N=sizeof(a)/sizeof(int);      //数组长度<BR>int *p=a;                         //数组指针</P>4 ~' c1 r/ Q4 v+ A* K: ?; A
<>void main()<BR>{<BR> permutation(p);    //调用全排列函数<BR> output(p);         //输出排列结果<BR> getch();<BR>}</P>; o+ y7 C" K+ v/ l8 u
<>void permutation(int *p)<BR>{<BR> bool flag=false;   //标志排列是否结束<BR> int temp;          //临时变量,用来交换数组元素</P>4 ]+ r" [+ x- H" e2 C; J
<> while(1)<BR> {<BR>  for(int i=0;i&lt;N-1;i++)<BR>  {<BR>   flag=true;     //如已排列完,falg为真</P>2 O. k7 q0 q# [* j# s+ {; `
<>   if(p&lt;p[i+1]) //如果发现第一个倒序的数组元素,p[i+1]被称为倒序元素<BR>   { <BR>    flag=false; //说明未排列完</P>
6 U% d$ P" N5 k; N+ \<>    int j=0;<BR>    while(p[j++]&gt;=p[i+1]); //找到第一个大于或等于倒序元素的数组元素<BR>    j-=1;                  </P>
+ L5 c0 G" Y8 f4 l1 K. i<>    temp=p[i+1];           //交换这两个元素<BR>    p[i+1]=p[j];<BR>    p[j]=temp;</P>
3 g. M+ T4 M# R& o* g( e2 L<>    j=0;<BR>    while(j&lt;(i+1)/2)       //倒置倒充元素原位置以前的所有元素<BR>    {<BR>     temp=p[j];<BR>     p[j]=p[i-j];<BR>     p[i-j]=temp;<BR>     <BR>     j++;<BR>    }    <BR>    break;                 //跳出for循环,<BR>   }<BR>  }<BR>  if(flag)                       //如果排列完,结束循环<BR>   break;<BR>  //output(p);                        //输出排列结果<BR> }<BR>}</P>0 @+ k7 i( n) h& ~
<>void output(int *p)<BR>{<BR> cout&lt;&lt;endl;<BR> for(int i=0;i&lt;N;i++)<BR>  cout&lt;&lt;p&lt;&lt;' ';</P>
, g  n2 W) W8 z" `  T% d; a% a$ |<>}<BR></P>
回复

使用道具 举报

dsg333        

1

主题

0

听众

21

积分

升级  16.84%

该用户从未签到

新人进步奖

回复

使用道具 举报

4

主题

2

听众

24

积分

升级  20%

该用户从未签到

新人进步奖

回复

使用道具 举报

zansan        

0

主题

3

听众

44

积分

升级  41.05%

该用户从未签到

新人进步奖

<p>&nbsp;<font color="#000000" size="+0">递归容易明白,就是慢,这个算法就是好.找到"倒置位"后进行倒置.</font></p>
回复

使用道具 举报

13

主题

3

听众

53

积分

升级  50.53%

该用户从未签到

新人进步奖

matlab里面好像有这个函数,我用过,但现在实在是既不起来了,你可以寻求帮助,但如果英语不太好,建议买一本参考教材看看相关命令,或者上网查一些有关命令的资料下载就是了,我的大部分matlab知识就是寻求网上帮助获得的,你也可以试试!
回复

使用道具 举报

sjian2001        

1

主题

3

听众

21

积分

升级  16.84%

该用户从未签到

新人进步奖

看过一篇文章是这么说的:<br/>比如说求1,2,3的全排列,<br/>先是{  1  }<br/>然后用2,在元素里所有空当插入<br/>变成了{ 21  , 12}<br/>然后用3,在元素里所有空当插入<br/>{321,231,213,312,132,123}<br/>算法还是好实现的。<br/>不知道跟其他算法有什么效率差别。<br/>
回复

使用道具 举报

您需要登录后才可以回帖 登录 | 注册地址

qq
收缩
  • 电话咨询

  • 04714969085
fastpost

关于我们| 联系我们| 诚征英才| 对外合作| 产品服务| QQ

手机版|Archiver| |繁體中文 手机客户端  

蒙公网安备 15010502000194号

Powered by Discuz! X2.5   © 2001-2013 数学建模网-数学中国 ( 蒙ICP备14002410号-3 蒙BBS备-0002号 )     论坛法律顾问:王兆丰

GMT+8, 2025-12-30 21:15 , Processed in 1.795920 second(s), 100 queries .

回顶部