• LeetCode 2582. 递枕头:清晰的话讲述 O(1)的时间算法


    【LetMeFly】2582.递枕头:清晰的话讲述 O(1)的时间算法

    力扣题目链接:https://leetcode.cn/problems/pass-the-pillow/

    n 个人站成一排,按从 1n 编号。

    最初,排在队首的第一个人拿着一个枕头。每秒钟,拿着枕头的人会将枕头传递给队伍中的下一个人。一旦枕头到达队首或队尾,传递方向就会改变,队伍会继续沿相反方向传递枕头。

    • 例如,当枕头到达第 n 个人时,TA 会将枕头传递给第 n - 1 个人,然后传递给第 n - 2 个人,依此类推。

    给你两个正整数 ntime ,返回 time 秒后拿着枕头的人的编号。

     

    示例 1:

    输入:n = 4, time = 5
    输出:2
    解释:队伍中枕头的传递情况为:1 -> 2 -> 3 -> 4 -> 3 -> 2 。
    5 秒后,枕头传递到第 2 个人手中。
    

    示例 2:

    输入:n = 3, time = 2
    输出:3
    解释:队伍中枕头的传递情况为:1 -> 2 -> 3 。
    2 秒后,枕头传递到第 3 个人手中。
    

     

    提示:

    • 2 <= n <= 1000
    • 1 <= time <= 1000

    方法一:计算

    n个人传递枕头,从左到右需要传递 n − 1 n-1 n1次。同理,从右到左也需要传 n − 1 n-1 n1次。也就是说, 2 × ( n − 1 ) 2\times(n-1) 2×(n1)次一循环。

    因此, t i m e time time直接模上个 2 × ( n − 1 ) 2\times(n-1) 2×(n1)即等效于单轮传递的结果。

    • 如果 t i m e ≤ n − 1 time\leq n-1 timen1,则说明是在往右传。传 0 0 0次处于 1 1 1,传 1 1 1次处于 2 2 2,…,传 t i m e time time次处于 t i m e + 1 time + 1 time+1

    • 否则,说明是在往左传。往左传了 t i m e − ( n − 1 ) time - (n - 1) time(n1)次。往左传 0 0 0次处于 n n n,往左传 1 1 1次处于 n − 1 n-1 n1,…,往左传 t i m e − ( n − 1 ) time - (n - 1) time(n1)次处于 n − ( t i m e − ( n − 1 ) ) = 2 ∗ n − t i m e − 1 n - (time - (n - 1)) = 2 * n - time - 1 n(time(n1))=2ntime1

    • 时间复杂度 O ( 1 ) O(1) O(1)

    • 空间复杂度 O ( 1 ) O(1) O(1)

    AC代码

    C++
    class Solution {
    public:
        int passThePillow(int n, int time) {
            time %= (n - 1) * 2;
            return time <= n - 1 ? time + 1 : 2 * n - time - 1;
        }
    };
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7
    Python
    class Solution:
        def passThePillow(self, n: int, time: int) -> int:
            time %= (n - 1) * 2
            return time + 1 if time <= n - 1 else 2 * n - time - 1
    
    • 1
    • 2
    • 3
    • 4

    同步发文于CSDN,原创不易,转载经作者同意后请附上原文链接哦~
    Tisfy:https://letmefly.blog.csdn.net/article/details/133294825

  • 相关阅读:
    爬虫逆向实战(32)-某号店登录(RSA、补环境、混淆)
    牛客网刷题(四)
    STS中打开Ibatis的xml文件提示错误
    计算机毕业设计springboot+vue基本微信小程序的健康管理系统
    老卫带你学---leetcode刷题(121. 买卖股票的最佳时机)
    计算机视觉与深度学习-经典网络解析-ZFNet-[北邮鲁鹏]
    E. Gardener and Tree(拓扑排序)
    python枚举详解
    你知道MySQL锁,到底在锁什么吗?
    Hive分区表和分桶表
  • 原文地址:https://blog.csdn.net/Tisfy/article/details/133294825