【leetcode——415场周赛】——python前两题

3289. 数字小镇中的捣蛋鬼

数字小镇 Digitville 中,存在一个数字列表 nums,其中包含从 0n - 1 的整数。每个数字本应 只出现一次 ,然而,有 两个顽皮的数字额外多出现了一次,使得列表变得比正常情况下更长。

为了恢复 Digitville 的和平,作为小镇中的名侦探,请你找出这两个顽皮的数字。

返回一个长度为 2 的数组,包含这两个数字(顺序任意)。

示例 1:

输入: nums = [0,1,1,0]

输出: [0,1]

解释:

数字 0 和 1 分别在数组中出现了两次。

示例 2:

输入: nums = [0,3,2,1,3,2]

输出: [2,3]

解释:

数字 2 和 3 分别在数组中出现了两次。

示例 3:

输入: nums = [7,1,5,4,3,4,6,0,9,5,8,2]

输出: [4,5]

解释:

数字 4 和 5 分别在数组中出现了两次。

提示:

  • 2 <= n <= 100
  • nums.length == n + 2
  • 0 <= nums[i] < n
  • 输入保证 nums恰好包含两个重复的元素。
python 复制代码
class Solution:
    def getSneakyNumbers(self, nums: List[int]) -> List[int]:
        dict1 = Counter(nums)
        l = []
        for i in dict1:
            if dict1[i] > 1:
                l.append(i)
        return l

时间复杂度:o(n),空间复杂度:o(n)

3290. 最高乘法得分

给你一个大小为 4 的整数数组 a 和一个大小 至少 为 4 的整数数组 b

你需要从数组 b 中选择四个下标 i0, i1, i2, 和 i3,并满足 i0 < i1 < i2 < i3。你的得分将是 a[0] * b[i0] + a[1] * b[i1] + a[2] * b[i2] + a[3] * b[i3] 的值。

返回你能够获得的 最大得分。

示例 1:

输入: a = [3,2,5,6], b = [2,-6,4,-5,-3,2,-7]

输出: 26

解释:

选择下标 0, 1, 2 和 5。得分为 3 * 2 + 2 * (-6) + 5 * 4 + 6 * 2 = 26

示例 2:

输入: a = [-1,4,5,-2], b = [-5,-1,-3,-2,-4]

输出: -1

解释:

选择下标 0, 1, 3 和 4。得分为 (-1) * (-5) + 4 * (-1) + 5 * (-2) + (-2) * (-4) = -1

提示:

  • a.length == 4
  • 4 <= b.length <= 10**5
  • -105 <= a[i], b[i] <= 10**5

一开始想的是记忆化搜索,但是爆了:

python 复制代码
#内存爆了
class Solution:
    def maxScore(self, a: List[int], b: List[int]) -> int:
        n = len(b)
        @cache
        def dfs(i : int, ans : int, step : int) -> int:
            if step == 4:
                return ans
            elif i >= n or step > 4:
                return -inf
            return max(dfs(i + 1,ans + a[step] * b[i],step + 1),dfs(i + 1,ans,step))
        return dfs(0,0,0)
python 复制代码
#时间爆了
class Solution:
    def maxScore(self, a: List[int], b: List[int]) -> int:
        n = len(b)
        @cache
        def dfs(i : int, ans : int, step : int) -> int:
            if step == 4:
                return ans
            elif i >= n or step > 4:
                return -inf
            return max(dfs(i + 1,ans + a[step] * b[i],step + 1),dfs(i + 1,ans,step))
        ans = dfs(0,0,0)
        dfs.cache_clear()
        return ans

最后改了动态规划才好

python 复制代码
class Solution:
    def maxScore(self, a: List[int], b: List[int]) -> int:
        n = len(b)

        dp = [[float('-inf')] * 5 for _ in range(n + 1)]
        dp[0][0] = 0 
        for i in range(n):
            for step in range(4, -1, -1):
                if step > 0:
                    dp[i + 1][step] = max(dp[i + 1][step], dp[i][step - 1] + a[step - 1] * b[i])
                dp[i + 1][step] = max(dp[i + 1][step], dp[i][step])
        return dp[n][4]
相关推荐
m0_603888715 分钟前
Scaling Trends for Multi-Hop Contextual Reasoning in Mid-Scale Language Models
人工智能·算法·ai·语言模型·论文速览
Xの哲學8 分钟前
Linux io_uring 深度剖析: 重新定义高性能I/O的架构革命
linux·服务器·网络·算法·边缘计算
comli_cn15 分钟前
残差链接(Residual Connection)
人工智能·算法
2501_9311624320 分钟前
大疆相机:空中影像新境界
python
Aaron158822 分钟前
基于VU13P在人工智能高速接口传输上的应用浅析
人工智能·算法·fpga开发·硬件架构·信息与通信·信号处理·基带工程
测试199823 分钟前
Web自动化测试入门
自动化测试·软件测试·python·功能测试·selenium·测试工具·测试用例
予枫的编程笔记24 分钟前
【论文解读】DLF:以语言为核心的多模态情感分析新范式 (AAAI 2025)
人工智能·python·算法·机器学习
im_AMBER33 分钟前
Leetcode 99 删除排序链表中的重复元素 | 合并两个链表
数据结构·笔记·学习·算法·leetcode·链表
lbb 小魔仙40 分钟前
【Python】零基础学 Python 爬虫:从原理到反爬,构建企业级爬虫系统
开发语言·爬虫·python
黄河里的小鲤鱼1 小时前
拯救草台班子-战略
人工智能·python·信息可视化