课后一个题u

MZJCDD 2008-04-20 04:45:20
17个人围成圈,编号为1-17,从第1号开始报数,报到3的倍数的人离开,一直数下去,直到最后剩下一个人 求此人的编号

#include<iostream.h>
void main()
{
const num=17;
int a[num];
for(int i=0;i<num;i++)
a[i]=i+1;
int k=0,m=-1,j=0;
while(k!=num)
{m=(m+1)%num;
if (a[m]==0)
m++;
j++;
if(j%3==0)
{cout<<a[m]<<"->";
a[m]=0;
k++;
}

}

}
我这个好像有点问题
帮忙改下
...全文
124 5 打赏 收藏 转发到动态 举报
写回复
用AI写文章
5 条回复
切换为时间正序
请发表友善的回复…
发表回复
sxsong_04 2008-04-20
  • 打赏
  • 举报
回复
#include<iostream>
using namespace std;

int main()
{
int num;
int i;
int j;
int count = 0;
cin>>num;
int* a = new int[num];
for(i = 0; i< num; i++)
a[i] = i+1;
i = 0;
j = 1;
while(count != num-1)
{
i = i%num ;
if(a[i] == 0)
{
i++;
continue;
}
if(j%3==0)
{
a[i] = 0;
count++;
}
j++;
i++;
}
i = 0;
while(1)
{
if(a[i]!=0)
{
cout<<a[i]<<endl;
break;
}
i++;
}
system("pause");
}
baihacker 2008-04-20
  • 打赏
  • 举报
回复


#include <iostream.h>
void main()
{
const int num=17;
int a[num];
for(int i=0;i <num;i++)
a[i]=i+1;
int k=0,m=0,j=0;
while(k!=num)
{
while(a[m]==0) m=(m+1)%num;
j++;
if(j%3==0)
{
cout << a[m] <<"->";
a[m]=0;
k++;
}
m=(m+1)%num;
}
}
baihacker 2008-04-20
  • 打赏
  • 举报
回复
http://topic.csdn.net/u/20080415/23/69de7f18-3aa8-46f6-bdf9-aa79a2a9518b.html
effective_person 2008-04-20
  • 打赏
  • 举报
回复
约瑟夫问题!!!
baidu吧!

64,642

社区成员

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

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