15个循环报数,报到N的出列,找出最后留下的那个人

ouyanghuahua 2010-05-01 03:39:43
代码如下:
#define TOTAL 15
int sn(int N)
{
int ring[TOTAL]={1,1,1,1,1,1,1,1,1,1,1,1,1,1,1};
int nextstart=0,i,counter;
for(i=1;i<TOTAL;i++)
{
counter =0;
while(counter<N)
{
if(-------)
ring[nextstart]=0;
do
{
---------;
---------;
}
while(!ring[nextstart])
counter++;
}
}
return nextstart+1;
}
有三个地方“-------”需要填空,我琢磨很久都没有弄出这程序的合理性,各位大侠帮帮忙。
...全文
122 4 打赏 收藏 转发到动态 举报
写回复
用AI写文章
4 条回复
切换为时间正序
请发表友善的回复…
发表回复
ithiker 2010-05-01
  • 打赏
  • 举报
回复
#include <stdio.h>
#define TOTAL 15
int sn(int N)
{
int ring[TOTAL]={1,1,1,1,1,1,1,1,1,1,1,1,1,1,1};
int nextstart=0,i,counter;
for(i=1;i<TOTAL;i++)
{
counter =0;
while(counter<N)
{
if(counter == N - 1)//已经数到N - 1后,第N个人出列
ring[nextstart]=0;
do
{
nextstart += 1;
nextstart %= TOTAL;//到队尾后从头开始
}while(!ring[nextstart]);//越过值为0的人,到1为止
counter++;//一共数到几
}
}
return nextstart+1;
}

int main()
{
printf("%d",sn(2));

return 0;
}
neohope 2010-05-01
  • 打赏
  • 举报
回复
作业要自己做哟
cattycat 2010-05-01
  • 打赏
  • 举报
回复
错了,if (counter==N-1)
cattycat 2010-05-01
  • 打赏
  • 举报
回复
if(counter==N)

do{
nextstart++;
nextstart%=TOTAL;
}

这个应该行吧

64,282

社区成员

发帖
与我相关
我的任务
社区描述
C++ 语言相关问题讨论,技术干货分享,前沿动态等
c++ 技术论坛(原bbs)
社区管理员
  • C++ 语言社区
  • encoderlee
  • paschen
加入社区
  • 近7日
  • 近30日
  • 至今
社区公告
  1. 请不要发布与C++技术无关的贴子
  2. 请不要发布与技术无关的招聘、广告的帖子
  3. 请尽可能的描述清楚你的问题,如果涉及到代码请尽可能的格式化一下

试试用AI创作助手写篇文章吧