这道题怎么做啊
有N个人围成一圈,顺序排号,从第一个人开始报数(从1到3),凡报到3的人就退出圈子,问:
最后留下的是原来的第几号的那位?(最好用指针和函数)。
经典帖子!在c经典100帖中有,现粘贴出:
#define nmax 50 main() { int i,k,m,n,num[nmax],*p; printf("please input the total of numbers:"); scanf("%d",&n); p=num; for(i=0;i<n;i++) *(p+i)=i+1; i=0; k=0; m=0; while(m<n-1) { if(*(p+i)!=0) k++; if(k==3) { *(p+i)=0; k=0; 3的倍数化置0! m++; } i++; if(i==n) i=0; } while(*p==0) p++; printf("%d is left\n",*p); }