CCF201712-2 游戏(100分)【模拟】


试题编号:201712-2
试题名称:游戏
时间限制:1.0s
内存限制:256.0MB
问题描述:
问题描述
  有 n个小朋友围成一圈玩游戏,小朋友从1至 n编号,2号小朋友坐在1号小朋友的顺时针方向,3号小朋友坐在2号小朋友的顺时针方向,……,1号小朋友坐在 n号小朋友的顺时针方向。
  游戏开始,从1号小朋友开始顺时针报数,接下来每个小朋友的报数是上一个小朋友报的数加1。若一个小朋友报的数为 k的倍数或其末位数(即数的个位)为 k,则该小朋友被淘汰出局,不再参加以后的报数。当游戏中只剩下一个小朋友时,该小朋友获胜。
  例如,当n=5, k=2时:
  1号小朋友报数1;
  2号小朋友报数2淘汰;
  3号小朋友报数3;
  4号小朋友报数4淘汰;
  5号小朋友报数5;
  1号小朋友报数6淘汰;
  3号小朋友报数7;
  5号小朋友报数8淘汰;
  3号小朋友获胜。

  给定 nk,请问最后获胜的小朋友编号为多少?
输入格式
  输入一行,包括两个整数 nk,意义如题目所述。
输出格式
  输出一行,包含一个整数,表示获胜的小朋友编号。
样例输入
5 2
样例输出
3
样例输入
7 3
样例输出
4
数据规模和约定
  对于所有评测用例,1 ≤  n ≤ 1000,1 ≤  k ≤ 9。
 

问题链接:CCF201712试题

问题描述(参见上文)

问题分析

  这是一个模拟题,关键在于数据表示。

  另外,使用模除可以实现循环,即下标的循环。这是程序中经常用的技术。

程序说明

  方法一:

  使用数组进行模拟,flag[]用于标记小朋友是否出局,flag[i]=false表示i+1号小朋友没有出局,flag[i]=true表示i+1号小朋友已经出局。

  程序中的其他做法都是套路。


  方法二:

  使用STL的向量vector进行模拟。


  方法三:

  使用STL的队列queue进行模拟。


提交后得100分的C++语言程序(方法三)如下:

/* CCF201712-2 游戏 */

#include<iostream>
#include<queue>
#include<stdio.h>

using namespace std;

int main()
{
    int n,k;
    queue<int> q;

    // 读入数据与队列初始化
    scanf("%d%d",&n,&k);
    for(int i=1; i<=n; i++)
        q.push(i);

    // 模拟出局过程
    int no=0, head;
    while(!q.empty()) {
        head = q.front();
        q.pop();

        no++;
        if(no % k == 0 || no % 10 == k)
            ;
        else
            q.push(head);
    }

    printf("%d\n", head);

    return 0;
}

提交后得100分的C++语言程序(方法二)如下:

/* CCF201712-2 游戏 */

#include <iostream>
#include <vector>

//#define DEBUG

using namespace std;

int main()
{
    int n, k;
    vector<int> v;

    // 读入数据
    cin >> n >> k;

    // 初始化
    for(int i=1; i<=n; i++)
        v.push_back(i);

    // 模拟出局过程
    int i = -1, no = 0;
    while(v.size() >= 2) {
        no++;

        i++;
        i %= v.size();
        if(no % k == 0 || no % 10 == k) {
            v.erase(v.begin() + i);
            i--;
        }
#ifdef DEBUG
        cout << "no=" << no << " i=" << i << " ";
        for(int i=0; i<(int)v.size(); i++)
            cout << " " << v[i];
        cout << endl;
#endif
    }

    // 输出结果
    cout << v[0] << endl;

    return 0;
}


提交后得100分的C++语言程序(方法一)如下:
/* CCF201712-2 游戏 */

#include <iostream>
#include <string.h>

using namespace std;

const int N = 1000;
bool flag[N];

int main()
{
    int n, k;

    // 读入数据
    cin >> n >> k;

    // 初始化
    memset(flag, false, sizeof(flag));

    // 模拟出局过程
    int i = -1, no = 0, cnt = n;
    while(cnt > 1) {
        i++;
        i %= n;
        if(!flag[i]) {
            no++;
            if(no % k == 0 || no % 10 == k) {
                flag[i] = true;

                cnt--;
            }
        }
    }

    // 输出结果
    for(i=0; i<n; i++)
        if(!flag[i]) {
            printf("%d\n", i + 1);
            break;
        }

    return 0;
}



评论 12
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值