当前位置:首页 > 牛客 > 牛客22296题解:关灯游戏胜负判断的模拟算法与代码实现

牛客22296题解:关灯游戏胜负判断的模拟算法与代码实现

7个月前 (09-12)

牛客22296题解:关灯游戏胜负判断的模拟算法与代码实现 牛客题解 模拟 C++ 第1张

一、题目解读

牛客22296题描述了一个关灯游戏:有n个灯泡,每个灯泡初始状态为关闭(0)或打开(1)。玩家Alice和Bob轮流操作,最后操作最后一个灯泡的人获胜。题目要求根据输入的灯泡状态序列,判断最终获胜者。核心在于通过状态序列推断最后一次操作的对象,从而确定胜负。

二、解题思路

采用简单模拟策略解题。代码通过循环依次读取每个灯泡的状态,仅记录最后一个灯泡的状态(last_bulb)。由于胜负取决于最后一个灯泡的操作权,无需考虑中间状态变化,直接根据最后状态判断:若last_bulb为打开(1),则Alice获胜;否则Bob获胜。该解法时间复杂度O(n),空间复杂度O(1),高效直观。

三、解题步骤

1. 初始化变量last_bulb = 0,表示初始状态未知或未记录。

2. 循环读取n个灯泡状态:

○ 若当前为最后一个灯泡(i == n - 1),更新last_bulb为当前状态。

3. 根据last_bulb值输出获胜者:若为1则输出"Alice",否则输出"Bob"。

四、代码与注释

#include <iostream>  
using namespace std;  

int main() {  
    int n;  
    cin >> n;         // 输入灯泡数量  

    int last_bulb = 0;  // 记录最后一个灯泡的状态  
    for (int i = 0; i < n; ++i) {  
        int state;  
        cin >> state;   // 读取当前灯泡状态  
        if (i == n - 1) {  // 若为最后一个灯泡  
            last_bulb = state;  // 更新记录  
        }  
    }  

    cout << (last_bulb? "Alice" : "Bob") << endl;  // 根据状态判断输出  
    return 0;  
}

五、总结

本题通过简化问题本质,将复杂游戏规则转化为对最后一个状态的追踪,避免了繁琐的逻辑模拟。代码利用循环直接获取关键信息,体现了“抓住核心,忽略冗余”的解题思想。掌握此类简化策略,对处理类似逻辑判断问题具有启发意义。

原创内容 转载请注明出处

分享给朋友:

相关文章

力扣1221:一次扫描解决分割平衡字符串 时间O(n)空间O(1)

力扣1221:一次扫描解决分割平衡字符串 时间O(n)空间O(1)

题目重解给定一个仅包含'L'和'R'的字符串,要求将其分割成尽可能多的子串,且每个子串中'L'和'R'的数量相等。例如输入"R...

力扣965题深度解析:单值二叉树的判断技巧

力扣965题深度解析:单值二叉树的判断技巧

重新解读题目 判断一棵二叉树是否为“单值二叉树”,即所有节点的值是否完全相同。题目看似简单,实则考验对树结构递归特性的理解。若一棵树的所有节点值相同,其必然满足:根节点与左右子树的值一致,且...

手搓顺序表类代码注释与详解:从零实现动态数组(新手教程)

一、简介和特点顺序表(Sequential List)是数据结构中基础的一种线性表,其特点是将数据元素存储在连续的内存空间中。通过数组实现,支持随机访问(即通过索引直接访问元素),适用于频繁随机读取的...

力扣3112题解法:带时间限制的最短路径问题解析(C++代码)

力扣3112题解法:带时间限制的最短路径问题解析(C++代码)

一、题目解读力扣3112题要求解决带时间限制的最短路径问题:给定一个有向图,节点具有消失时间,需计算从起点到各节点的最短路径,且路径总时间不能超过节点的消失时间。题目难点在于需在传统最短路径算法(如D...

【洛谷1184题解析】用C++高效解决地点匹配问题(附代码与解题思路)

【洛谷1184题解析】用C++高效解决地点匹配问题(附代码与解题思路)

一、题目解读洛谷1184题要求处理一组地点列表与行程记录,统计其中匹配的天数。题目难点在于高效处理带有空格的字符串输入,以及快速判断每日行程是否在高手可去地点集合中。需要兼顾输入格式解析与算法效率。二...

牛客NC67题解:汉诺塔递归算法与解题步骤

牛客NC67题解:汉诺塔递归算法与解题步骤

一、题目解读牛客NC67题要求解决汉诺塔问题,这是一个经典的递归算法题目。题目给定整数n,代表汉诺塔中的盘子数量,需要输出将n个盘子从起始柱移动到目标柱的所有步骤。汉诺塔问题规则为:每次只能移动一个盘...

发表评论

访客

看不清,换一张

◎欢迎参与讨论,请在这里发表您的看法和观点。