北落师门


私信TA

用户名:blsm

访问量:4173

签 名:

等  级
排  名 8549
经  验 1222
参赛次数 0
文章发表 13
年  龄 0
在职情况 学生
学  校 湖北大学
专  业

  自我简介:

解题思路:数组模拟,初始化为0,循环数组,当j为3时,将该数组值置为-1,代表退出圈子,当k=1时,退出while循环,此时数组值为0的即为最终存活的人

注意事项:注意数组从零开始,最后输出需要加1

参考代码:

#include <memory.h>
int main()
{
    int n,d;
    scanf("%d",&n);

    d=3;
    int a[n];
    
    memset(a,0,sizeof(a));
    int j,k;
    j=0;
    k=n;
    while(k>1)
    {    
        for(int i=0;i<n;i++)
        {

            if(a[i]==0)
            {
                j++;
                if(j==d)
                {
                    a[i]=-1;
                    k--;
                    j=0;
                }
                    
            }
            
        }//end of for
        
    }//end of while
    
    while(--n>=0)
        if(a[n]==0)
            printf("%d\n",n+1);//数组从0开始,0是第一个人 
}


 

0.0分

0 人评分

  评论区

  • «
  • »