不好意思没说清楚.再说一次:手里有一叠牌A到K。从上往下开始,把第一张翻开到桌面上是A;接着开始数1,2,把1牌放到这叠牌的底部,数到2时翻开到桌面,点数时2;接着开始数1,2,3,1,2顺次方到底部,第3张翻开到桌面是3... ...如此到最后桌面上摆的牌按顺序是A,2,3,4,5,6,7,8,9,10,J,Q,K。求开始时候派在受理的顺序
#include "stdio.h"
#include "conio.h"
void Mov(int);
int a[13]={0};
void main()
{
int i;
a[12]=13;
a[11]=12;
for(i=1;i<=11;i++)
Mov(11-i); /*传递的是下标*/
for(i=0;i<13;i++)
printf("%5d",a[i]);
getch();
}
void Mov(int m)
{
int n,i;
int b[13]={0};
n=(m+1)%(12-m); /*m+1为上翻次数,12-m为当前牌数量*/
for(i=12;i>=m+1;i--) /*相当于把原来的几张牌向后移n位*/
if(i+n>12)
b[i+n-13]=a[i]; /*移出的保存在别的数组*/
else
a[i+n]=a[i]; /*做n位移动*/
for(i=0;b[i]!=0;i++)
a[m+1+i]=b[i]; /*把移出的放回*/
a[m]=m+1;
}