LeetCode 第401场周赛个人题解

100325. 找出 K 秒后拿着球的孩子

原题链接

100325. 找出 K 秒后拿着球的孩子

思路分析

数据很小,暴力或者数学方法都行

数学方法就是对 n - 1做带余除法,看跑了奇数还是偶数趟,余数如何,确定位置

时间复杂度:O(1)

AC代码

python 复制代码
class Solution:
    def numberOfChild(self, n: int, k: int) -> int:
        a, r = divmod(k, n - 1)
        if a & 1:
            return n - 1 - r
        return r

100305. K 秒后第 N 个元素的值

原题链接

100305. K 秒后第 N 个元素的值

思路分析

为了抢时间直接暴力了

时间复杂度O(NK)

AC代码

python 复制代码
class Solution:
    def valueAfterKSeconds(self, n: int, k: int) -> int:
        a = [1] * n
        for _ in range(k):
            for i in range(1, n):
                a[i] += a[i - 1]
                a[i] %= (10**9 + 7)
        return a[n - 1]

100319. 执行操作可获得的最大总奖励 I

原题链接

100319. 执行操作可获得的最大总奖励 I

思路分析

见下面

AC代码

python 复制代码
from sortedcontainers import SortedList
class Solution:
    def maxTotalReward(self, w: List[int]) -> int:
        w = sorted(set(w))
        n = len(w)
        st, msk, p = 1, 0, 0
        for i in range(n):
            while p < w[i]:
                msk |= (1 << p) & st
                p += 1
            st |= msk << w[i]
        res = w[-1] * 2 - 1
        while not (st >> res & 1):
            res -= 1
        return res

100320. 执行操作可获得的最大总奖励 II

原题链接

100320. 执行操作可获得的最大总奖励 II

思路分析

其实就是01背包,每个数字选或不选

我们将物品升序排序

定义状态f(i, j)为前 i 个数是否能够凑够j

f(i, j) = { f(i, j) | f(i, j - w[i]) } | f(i - 1, j)

只涉及或运算,我们考虑bitset优化

分别记录当前集合的状态f, 和w[i]位之前的状态msk

那么f = f | msk

时间复杂度:O(NM / 64)

略解释一下bitset优化:我们每次都是将当前行的一段状态和上一行的一段状态做或运算,一个一个做太慢了,所以我们用二进制位来表示每一行的每个元素的状态,一个int可以表示32个状态,longlong同理,事实上按题面的数据量来说不一定能过,但是......

AC代码

python 复制代码
from sortedcontainers import SortedList
class Solution:
    def maxTotalReward(self, w: List[int]) -> int:
        w = sorted(set(w))
        n = len(w)
        st, msk, p = 1, 0, 0
        for i in range(n):
            while p < w[i]:
                msk |= (1 << p) & st
                p += 1
            st |= msk << w[i]
        res = w[-1] * 2 - 1
        while not (st >> res & 1):
            res -= 1
        return res
相关推荐
哭泣的眼泪4089 分钟前
解析粗糙度仪在工业制造及材料科学和建筑工程领域的重要性
python·算法·django·virtualenv·pygame
清炒孔心菜19 分钟前
每日一题 LCR 078. 合并 K 个升序链表
leetcode
Microsoft Word1 小时前
c++基础语法
开发语言·c++·算法
天才在此1 小时前
汽车加油行驶问题-动态规划算法(已在洛谷AC)
算法·动态规划
莫叫石榴姐2 小时前
数据科学与SQL:组距分组分析 | 区间分布问题
大数据·人工智能·sql·深度学习·算法·机器学习·数据挖掘
茶猫_3 小时前
力扣面试题 - 25 二进制数转字符串
c语言·算法·leetcode·职场和发展
肥猪猪爸5 小时前
使用卡尔曼滤波器估计pybullet中的机器人位置
数据结构·人工智能·python·算法·机器人·卡尔曼滤波·pybullet
readmancynn5 小时前
二分基本实现
数据结构·算法
萝卜兽编程5 小时前
优先级队列
c++·算法
盼海5 小时前
排序算法(四)--快速排序
数据结构·算法·排序算法