猴子选大王C/C++(两种方法)

本关任务:编写一个函数 king,实现猴子选大王的功能。

新猴王的选择方法是:让 N 只候选猴子围成一圈(最多100只猴子),从某位置起顺序编号为 1 ~ N 号。从第1号开始报数,每轮从1报到3,凡报到3的猴子即退出圈子,接着又从紧邻的下一只猴子开始同样的报数。如此不断循环,最后剩下的一只猴子就选为猴王。
在右侧编辑器中的Begin-End之间补充代码,输出 N(数据由平台提供,已获取,直接使用即可) 只猴子中谁是猴子大王的。具体要求如下:

让 N 只候选猴子围成一圈(最多100只猴子),从某位置起顺序编号为 1 ~ N 号;

从第 1 号开始报数,每轮从 1 报到 3 ,凡报到 3 的猴子即退出圈子,接着又从紧邻的下一只猴子开始同样的报数;
如此不断循环,最后剩下的一只猴子就选为猴王。

测试输入:5
预期输出:4号猴子是大王。

测试输入:18
预期输出:14号猴子是大王。
实现如下:

#include <iostream>
using namespace std;

// 函数king:猴子选大王
// 参数:a-猴子数组n-1个猴子分别占据下标为~n-1的位置,n-数组长度
// 返回值:新猴王的下标序号
int king(int a[], int n);

int main()
{
    int n, a[1000], i;     // 定义变量及数组,n-猴子数量,a-猴子数组
    cin >> n;     // 输入猴子数量,n>0

    // 初始化猴子数组,n 个猴子分别占据 n 个位置
    a[0] = 0; // 0号位置没有猴子
    for(i = 1;i <= n; i++)
        a[i] = i;

    // 选大王啦
    i = king(a, n );
    cout << i << "号猴子是大王。" << endl;
    return 0;
}

int king(int a[], int n)
{
    // 请在此添加代码,实现函数king
    /********** Begin *********/
    int i,j,t=0;
    for(i=0;i<=n;i++)
        a[i]=1;
    for(i=1;i<=n;i++)
    {
        j=1;
        while(j<=3)
        {
            t=(t+1)%n;
            if(a[t]==1)j++;
        }
        a[t]=0;
    }
    return t;
    /********** End **********/
}

数学公式法:

#include <stdio.h>
int main()
{
    int n, m, i, s = 0;
    printf ("N M = ");
    scanf("%d%d", &n, &m);
    for (i = 2; i <= n; i++)
    {
        s = (s + m) % i;
    }
    printf ("\nThe winner is %d\n", s+1);
}
  • 20
    点赞
  • 94
    收藏
    觉得还不错? 一键收藏
  • 4
    评论
猴子大王是一个经典的问题,可以使用 C 语言中的数组来解决。 假设有 n 只猴子,我们可以用一个长度为 n 的数组来表示它们的编号,如下所示: ```c int monkeys[n]; ``` 接着,我们可以使用一个循环来初始化数组,将每只猴子的编号赋值给对应的数组元素: ```c for (int i = 0; i < n; i++) { monkeys[i] = i + 1; } ``` 这样,数组中的每个元素就表示一只猴子的编号。 接下来,我们可以使用一个 while 循环来模拟猴子大王的过程。具体地,我们可以使用两个变量 current 和 next 分别表示当前手和下一个手的索引,然后在循环中不断更新它们的值,直到只剩下一只猴子为止。具体代码如下: ```c int current = 0, next = 1; while (n > 1) { // 当前中下一个手 current = (current + m - 1) % n; // 计算出下一个手的索引 next = (current + 1) % n; // 将下一个手的编号移到当前手的位置上 monkeys[current] = monkeys[next]; // 将数组缩小一个元素 n--; } ``` 在这段代码中,变量 m 表示手之间的间隔(即每次数到第 m 只猴子时,该猴子出局),而变量 n 则表示当前还剩下的猴子数。 最后,当循环结束时,数组中仅剩下一个元素,即为猴子大王的编号。完整的代码如下: ```c #include <stdio.h> int main() { int n, m; printf("请输入猴子的数量和手之间的间隔:"); scanf("%d%d", &n, &m); int monkeys[n]; for (int i = 0; i < n; i++) { monkeys[i] = i + 1; } int current = 0, next = 1; while (n > 1) { current = (current + m - 1) % n; next = (current + 1) % n; monkeys[current] = monkeys[next]; n--; } printf("猴子大王的编号是:%d\n", monkeys[0]); return 0; } ``` 注意,在实际编写代码时,需要注意数组下标的范围,以及数组长度为 0 的情况。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 4
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值