解题思路:
注意事项:
参考代码:
#include <stdio.h>
int main()
{
int n,tt=0,num=0;//tt是推出淘汰的人数,num是用来报数的;
int a[100];
scanf("%d",&n);
for(int j=1;j<=n;j++)
a[j]=j;
int i=1;//为i赋初值;
while(n-tt!=1)//直到最后剩下一个人的时候结束循环;
{
if(a[i]!=0)
num++;//当a[i]不是0的时候,继续报数;
if(num==3)
{
a[i]=0;
tt++;//淘汰的人a[i]赋值为0,tt计数;
num=0;//将num重新为0,下一个人开始从1报数;
}
i++;
if(i==n+1)
{
i=1;
}
}
for(int k=1;k<=n;k++)
{
if(a[k]!=0)
{
printf("%d",k);
}
}
return 0;
}
0.0分
0 人评分
C语言程序设计教程(第三版)课后习题3.7 (C语言代码)浏览:449 |
三角形 (C++代码)递归(存在大量重复计算,容易出现时间超限)浏览:781 |
C语言程序设计教程(第三版)课后习题6.5 (C语言代码)浏览:595 |
C语言程序设计教程(第三版)课后习题1.5 (C语言代码)浏览:531 |
简单的a+b (C语言代码)浏览:512 |
C语言程序设计教程(第三版)课后习题6.1 (C语言代码)浏览:514 |
买不到的数目 (C语言代码)浏览:3094 |
字符删除 (C语言代码)浏览:721 |
C语言程序设计教程(第三版)课后习题10.1 (C++代码)浏览:503 |
平方数问题,oj一直是wrong answer浏览:739 |