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

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

3个月前 (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;  
}

五、总结

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

原创内容 转载请注明出处

分享给朋友:

相关文章

线性遍历+二进制 6行代码征服二进制链表转整数

线性遍历+二进制 6行代码征服二进制链表转整数

力扣1290.二进制链表转整数题目本质给定一个单链表的头节点head,链表中每个节点的值为0或1。链表表示一个‌最高有效位在前‌的二进制数字,要求将其转换为对应的十进制整数。例如链表1→0→1对应的二...

牛客DP41精讲:当背包必须装满时,你的状态转移方程该如何调整?

牛客DP41精讲:当背包必须装满时,你的状态转移方程该如何调整?

题目重解我们面对一个经典背包问题的变体:给定n个物品,每个物品有重量w和价值v,背包容量为V。需要回答两个问题:1) 普通情况下能获得的最大价值;2) 必须恰好装满背包时的最大价值(若无法装满则输出0...

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

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

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

洛谷1220题解:动态规划与区间DP优化解法(附代码注释)

洛谷1220题解:动态规划与区间DP优化解法(附代码注释)

一、题目解读洛谷1220题要求计算在n个位置放置灯的情况下,通过关闭连续区间灯并移动至区间端点,使得总耗电量最小。需考虑灯的功率与位置差异,设计高效的算法求解最优策略。二、解题思路1. 动态规划 +...

洛谷P2190题解:铁路售票系统车厢计算(差分数组+前缀和优化)

洛谷P2190题解:铁路售票系统车厢计算(差分数组+前缀和优化)

一、题目解读洛谷P2190题要求解决铁路售票系统中的车厢数量计算问题。题目给定n个车站和m条订票申请,每条申请包含区间[x,y)及乘客数z。需要计算在不超载的情况下(每节车厢最多36人),满足所有乘客...

洛谷2652题解析:同花顺排序问题的动态规划与滑动窗口优化

洛谷2652题解析:同花顺排序问题的动态规划与滑动窗口优化

一、题目解读洛谷2652题要求对一组扑克牌进行排序,目标是找到最少需要调整的次数,使得所有牌形成同花顺。题目中,扑克牌由花色和数字组成,需先按花色排序,再在同花色内按数字排序。核心难点在于如何处理花色...

发表评论

访客

看不清,换一张

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