取沙子游戏

Problem K. 取沙子游戏

https://codeforces.com/gym/105336

代码

cpp 复制代码
#include <bits/stdc++.h>
#define endl "\n"
using namespace std;

int lowbit(const int &n) // 求lowbit
{
    return n & (-n);
}

void Solution() // Solution一般来说不用传参
{
    int n, k; // n粒沙子,每次取沙子,且数量不超过k
    cin >> n >> k;
    if (k >= n) // 1.如果k>=n,则Alice可以一次取完,必胜。
    {
        cout << "Alice" << endl;
        return;
    }
    // k<n的情况
    if (lowbit(n) <= k) // 2.如果lowbit小于等于k,则Alice必赢。Alice取lowbit,后面不管Bob怎么取,都和Bob取一样的,这样Alice肯定是。3.这里面包含了n为奇数,则Alice第一次取一个就必胜的情况。因为此时lowbit(n)=1,一定满足lowbit(n)<=k。
    {
        cout << "Alice" << endl;
        return;
    }
    else // 4.否则的话,Alice不一定赢
    {
        cout << "Bob" << endl;
        return;
    }
}

int main()
{
    ios::sync_with_stdio(false);
    cin.tie(nullptr);

    int T; // T组数据
    cin >> T;
    while (T--)
    {
        Solution();
    }
    return 0;
}

​ 这道题思路很重要,总共分为四种情况。

  1. k>=n。这种情况下,Alice可以在第一次直接全部取完,Alice必胜。
  2. n为奇数。Alice第一次取一个就必胜。(这也是lowbit(n)<=k的情况,代码中没有另外作为一种情况写出)
  3. n为偶数且lowbit(n)<=k。这种情况下,只要Alice第一次取lowbit(n),后面不管Bob取什么,Alice都和Bob选一样的,就可以使得除了第一次Alice取的次数外取了偶数次,Alice必赢。
  4. n为偶数且lowbit(n)>k。这种情况下,Alice就不一定必胜,所以输出Bob。
  • 补充lowbit知识。Lowbit函数是一种特殊的位操作,用于找到一个数的最低位的1。
cpp 复制代码
int lowbit(const int &n) // 求lowbit
{
    return n & (-n);
}

传奇计算机大神miyou的亲笔稿:

相关推荐
魔法阵维护师1 小时前
从零开发游戏需要学习的c#模块,第三十五章(打包发布 —— 让别人玩你的游戏)
学习·游戏·c#
wgc2k1 小时前
Node.js游戏服务器项目移植-1:项目移植版本环境的冲突问题以及技术选型测试
游戏·node.js
Kurisu5752 小时前
最终幻想VII重制版修改器下载2026最新版
linux·游戏
前端不太难2 小时前
鸿蒙游戏 HUD 如何设计?
游戏·状态模式·harmonyos
wgc2k5 小时前
Node.js游戏服务器项目移植-2: 用TypeScript还是Javascript
服务器·游戏·node.js
海兰12 小时前
【文字三国志:第一篇】天命重构,大语言模型(LLM)动态生成文言风格的叙事文本的文字游戏
人工智能·游戏·语言模型
魔法阵维护师1 天前
从零开发游戏需要学习的c#模块,第三十四章(设置界面)
学习·游戏·c#
海兰1 天前
【文字三国志:第五篇】天命重构,游戏前端UI设计
前端·人工智能·游戏·语言模型
ShyanZh2 天前
从0开始做自己的免费游戏聚合站(三):接入 GamerPower API,聚合 Steam 免费游戏
游戏·steam·喜加一
Oiiouui2 天前
Godot(4.x): 游戏管理器: Godot 内注入数据处理与总接口实现
游戏·游戏引擎·godot