当前位置: 代码迷 >> C语言 >> 这道题怎么做啊
  详细解决方案

这道题怎么做啊

热度:298   发布时间:2004-11-24 16:02:00.0
这道题怎么做啊

有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); }


----------------解决方案--------------------------------------------------------

退出一个人以后是接着退出那个人后面的开始数1,2,3吗?


----------------解决方案--------------------------------------------------------
  相关解决方案