解题思路:题目要我们遇到三就让他退出,那我们不妨定义一个数组,让其中n个数都等于1,然后我们便让他们按顺序相加,当加起来等于三=3时,我们就让当这个数组等于0,最后当数组的n个数加起来等于1时,就只有当前这个数等于1了,我们把他的位置输出出来就是他的号码了。

注意事项:

参考代码:

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
#include <stdio.h>
int main()
{
    int x[100], i, n,sum=0,add=0;
    scanf("%d", &n);;
    for (i = 0;i < n;i++)//让这些数都等于1
    {
        x[i] = 1;
    }
    while(1)
    {
        for (i=0;i<n;i++)
        {
            sum += x[i];
            if (sum == 3)
            {
                x[i] = 0;
                sum = 0;
            }
        }
        for(i=0;i<n;i++)//让这些数加起来
        {
            add += x[i];
        }
        if (add == 1)//这些数加起来等于一就只剩下一个数了
        {
            break;
        }
        else//不是1就重新判断
        {
            add = 0;
        }
    }
    for (i = 0;i < n;i++)找出其中等于1的数组输出
    {
        if (x[i] == 1)
        {
            printf("%d", i+1);
        }
    }
    return 0;
}


点赞(0)
 

9.9 分

3 人评分

 

C语言网提供由在职研发工程师或ACM蓝桥杯竞赛优秀选手录制的视频教程,并配有习题和答疑,点击了解:

一点编程也不会写的:零基础C语言学练课程

解决困扰你多年的C语言疑难杂症特性的C语言进阶课程

从零到写出一个爬虫的Python编程课程

只会语法写不出代码?手把手带你写100个编程真题的编程百练课程

信息学奥赛或C++选手的 必学C++课程

蓝桥杯ACM、信息学奥赛的必学课程:算法竞赛课入门课程

手把手讲解近五年真题的蓝桥杯辅导课程

评论列表 共有 0 条评论

暂无评论