当前位置: 首页 > news >正文

Leetcode 3202. Find the Maximum Length of Valid Subsequence II

  • Leetcode 3202. Find the Maximum Length of Valid Subsequence II
    • 1. 解题思路
    • 2. 代码实现
  • 题目链接:3202. Find the Maximum Length of Valid Subsequence II

1. 解题思路

这一题的话是上一题3201. Find the Maximum Length of Valid Subsequence I的升级版,主要就是将除数2调整为任意正数k,但是本质上还是一样的,我们同样有奇数位和偶数位上的数必然对k有着相同的余数,此时,我们只需要考察前两个元素的余数组合,然后考察他们的所有位置能够组成的交叉序列的最大长度即可。

当前两个元素的余数相同时,我们能够获得的最大子序列的长度就是k的余数相同的元素出现的最大频次。

当前两个元素的余数不同时,我们能够快速得到两个余数的位置序列,然后我们通过贪婪算法配合二分搜索即可快速得到他们能够组成的最大交叉序列长度。

最后,如果两个序列的长度之后都小于当前已经获得的最大序列长度了,我们就可以直接跳过这些可能性了,由此,我们即可进一步对问题进行剪枝,从而得到我们最终的答案。

2. 代码实现

给出python代码实现如下:

class Solution:def maximumLength(self, nums: List[int], k: int) -> int:locs = defaultdict(list)for i, x in enumerate(nums):locs[x%k].append(i)ans = max(len(x) for x in locs.values())def get_max_length(s1, s2):n, m = len(s1), len(s2)i, j = 0, 0cnt = 1 if s2[0] < s1[0] else 0while i < n:cnt += 1j = bisect.bisect_left(s2, s1[i])if j < m:cnt += 1else:breaki = bisect.bisect_left(s1, s2[j])return cntfor i in range(k-1):if locs[i] == []:continuefor j in range(i+1, k):if len(locs[i]) + len(locs[j]) <= ans:continuecnt = get_max_length(locs[i], locs[j])ans = max(ans, cnt)return ans

提交代码评测得到:耗时277ms,占用内存16.8MB。

http://www.lryc.cn/news/390230.html

相关文章:

  • 通过Spring Boot结合实时流媒体技术对考试过程进行实时监控
  • 智能扫地机器人避障与防跌落问题解决方案
  • 德旺训练营称重问题
  • 数据决策系统详解
  • JSON 简述与应用
  • ResNet50V2
  • 基于深度学习的虚拟换装
  • 单段时间最优S型速度规划算法
  • pom文件-微服务项目结构
  • 解析Kotlin中的Nothing【笔记摘要】
  • toRefs 和 toRef
  • Vision Transformer论文阅读笔记
  • MapReduce的执行流程排序
  • 雅思词汇及发音积累 2024.7.3
  • Vue2和Vue3的区别Vue3的组合式API
  • ML307R OpenCPU HTTP使用
  • 【状态估计】线性高斯系统的状态估计——离散时间的递归滤波
  • 架构设计上中的master三种架构,单节点,主从节点,多节点分析
  • 如何在 SQL 中删除一条记录?
  • JavaSE (Java基础):面向对象(上)
  • flink使用StatementSet降低资源浪费
  • FineDataLink4.1.9支持Kettle调用
  • SwanLinkOS首批实现与HarmonyOS NEXT互联互通,软通动力子公司鸿湖万联助力鸿蒙生态统一互联
  • Win11禁止右键菜单折叠的方法
  • Maven列出所有的依赖树
  • 测试开发面试题和答案
  • llm学习-3(向量数据库的使用)
  • 【01-02】Mybatis的配置文件与基于XML的使用
  • Linux-进程间通信(IPC)
  • C++ STL: std::vector与std::array的深入对比