queue队列算法模板-附LeetCode每日一题题解:1823. 找出游戏的获胜者-题解-python && C++源代码

简介: queue队列算法模板-附LeetCode每日一题题解:1823. 找出游戏的获胜者-题解-python && C++源代码

1823. 找出游戏的获胜者


难度中等66收藏分享切换为英文接收动态反馈


共有 n 名小伙伴一起做游戏。小伙伴们围成一圈,按 顺时针顺序 从 1 到 n 编号。确切地说,从第 i 名小伙伴顺时针移动一位会到达第 (i+1) 名小伙伴的位置,其中 1 <= i < n ,从第 n 名小伙伴顺时针移动一位会回到第 1 名小伙伴的位置。


游戏遵循如下规则:


从第 1 名小伙伴所在位置 开始 。

沿着顺时针方向数 k 名小伙伴,计数时需要 包含 起始时的那位小伙伴。逐个绕圈进行计数,一些小伙伴可能会被数过不止一次。

你数到的最后一名小伙伴需要离开圈子,并视作输掉游戏。

如果圈子中仍然有不止一名小伙伴,从刚刚输掉的小伙伴的 顺时针下一位 小伙伴 开始,回到步骤 2 继续执行。

否则,圈子中最后一名小伙伴赢得游戏。

给你参与游戏的小伙伴总数 n ,和一个整数 k ,返回游戏的获胜者。


示例 1:


image.png


输入:n = 5, k = 2

输出:3

解释:游戏运行步骤如下:

1) 从小伙伴 1 开始。

2) 顺时针数 2 名小伙伴,也就是小伙伴 1 和 2 。

3) 小伙伴 2 离开圈子。下一次从小伙伴 3 开始。

4) 顺时针数 2 名小伙伴,也就是小伙伴 3 和 4 。

5) 小伙伴 4 离开圈子。下一次从小伙伴 5 开始。

6) 顺时针数 2 名小伙伴,也就是小伙伴 5 和 1 。

7) 小伙伴 1 离开圈子。下一次从小伙伴 3 开始。

8) 顺时针数 2 名小伙伴,也就是小伙伴 3 和 5 。

9) 小伙伴 5 离开圈子。只剩下小伙伴 3 。所以小伙伴 3 是游戏的获胜者。

示例 2:


输入:n = 6, k = 5

输出:1

解释:小伙伴离开圈子的顺序:5、4、6、2、3 。小伙伴 1 是游戏的获胜者。


解题思路:

队列真是个神奇的数据结构,个人认为用起来要比list列表舒服多了,至少这可以两边互相弹出插入,而且速度要比列表快

在这道题中,我们首先构造一个队列,将1到n塞进去,然后我们例如队列可以左右互插的特点,因为每次要把第k个数搞出去,

所以我们每次只需要将前k-1个数放到队列最后,然后第k个数就变成了在队列首位,弹出即可,反复进行即可。


python代码:

class Solution:
    def findTheWinner(self, n: int, k: int) -> int:
        ans = deque(range(1 , n+1))#建立 0 到 n+1的队列
        while len(ans)>1: #等数组的个数到一个的时候,就跳出循环,输出即可
            for i in range(k-1):#将队列的前k-1位都放到队列最后
                ans.append(ans.popleft())#将第K位提到首位
            ans.popleft()#然后弹出首位
        return ans[0]#返回首位即是留下的值

C++代码:

class Solution {
public:
    int findTheWinner(int n, int k) {
        queue<int> ans;
        for(int i=1; i<n+1; i++) ans.emplace(i); //建立 0 到 n+1的队列
        while(ans.size()>1){  //等数组的个数到一个的时候,就跳出循环,输出即可
            for (int i=0; i<k-1; i++){ //将队列的前k-1位都放到队列最后
                ans.emplace(ans.front()); //将第K位提到首位
                ans.pop(); 
            }
            ans.pop(); //然后弹出首位
        }
        return ans.front();//返回首位即是留下的值
    }
};
相关文章
|
11月前
|
Java C++
力扣第一道困难题《3. 无重复字符的最长子串》,c++
首先我们看到这个题是肯定有一种暴力的硬解思路的,那就是将两个vector直接链接起来,然后再排序后,直接返回中间值,这个方法实现起来还是非常容易的,
406 0
|
算法 安全 搜索推荐
套用算法模板备案审核问题增多的原因及解决建议
随着算法备案要求的完善,企业常因使用网上廉价模板而遭遇审核通过率低、问题增多的困境。本文分析了审核不通过的原因,包括模板缺乏针对性、审核标准严格、审核人员主观差异及企业准备不足等,并提出建议:深入了解备案要求、准备详尽材料、避免通用模板、寻求专业帮助。备案后还需持续合规管理,确保算法服务安全运行。
|
缓存 监控 算法
内网监控管理软件:PHP 语言队列算法揭秘
在数字化办公环境中,内网监控管理软件对企业的稳定运行和信息安全至关重要。本文深入介绍PHP中的队列算法及其在内网监控软件中的应用,包括监控数据收集、任务调度和日志记录等场景,通过代码示例展示其实现方法。队列算法可提高性能、保证数据顺序并实现异步处理,为企业提供高效的安全保障。
257 1
|
算法 安全 NoSQL
2024重生之回溯数据结构与算法系列学习之栈和队列精题汇总(10)【无论是王道考研人还是IKUN都能包会的;不然别给我家鸽鸽丢脸好嘛?】
数据结构王道第3章之IKUN和I原达人之数据结构与算法系列学习栈与队列精题详解、数据结构、C++、排序算法、java、动态规划你个小黑子;这都学不会;能不能不要给我家鸽鸽丢脸啊~除了会黑我家鸽鸽还会干嘛?!!!
|
缓存 算法 Java
刷算法,你应该知道的队列经典应用
文章介绍了队列的基本特性和经典应用,包括如何用队列实现栈、使用优先级队列解决Top K问题,并通过LeetCode题目示例展示了队列在算法实现中的应用。
刷算法,你应该知道的队列经典应用
|
存储 算法 前端开发
深入理解操作系统:进程调度与优先级队列算法
【9月更文挑战第25天】在操作系统的复杂世界中,进程调度是维持系统稳定运行的核心机制之一。本文将深入探讨进程调度的基本概念,分析不同的进程调度算法,并着重介绍优先级队列算法的原理和实现。通过简洁明了的语言,我们将一起探索如何优化进程调度,提高操作系统的效率和响应速度。无论你是计算机科学的初学者还是希望深化理解的专业人士,这篇文章都将为你提供有价值的见解。
|
存储 算法 定位技术
数据结构与算法学习二、稀疏数组与队列,数组模拟队列,模拟环形队列
这篇文章主要介绍了稀疏数组和队列的概念、应用实例以及如何使用数组模拟队列和环形队列的实现方法。
243 0
数据结构与算法学习二、稀疏数组与队列,数组模拟队列,模拟环形队列
|
算法 数据挖掘
【栈和队列】算法题 ---- 力扣(二)
【栈和队列】算法题 ---- 力扣
|
存储 算法
【栈和队列】算法题 ---- 力扣(一)
【栈和队列】算法题 ---- 力扣
【LeetCode 24】225.用队列实现栈
【LeetCode 24】225.用队列实现栈
138 0

热门文章

最新文章

推荐镜像

更多