2024.6.8

2024.6.8

**每日一题**

3040.相同分数的最大操作数目 Ⅱ,通多题意可知,该题最多有三种操作分数,分别是前两个,最后两个,以及第一个和最后一个的和。从这里也可以看出一共有三种状态转移方式,所以我们可以利用DP或者记忆化搜索的方式来求解。对三种操作分数分别求最大次数,再求他们的最大值。依次判断三个状态,当前区间的前面两个,最后两个,以及第一个和最后一个,直到遍历区间长度为1就可以求出整个区间的答案。

516.最长回文子序列,该题是一个区间求最值问题,我们自然地想到可以通过小区间转移到大区间来进行求解,状态转移就对应着动态规划或者搜索算法。在本题中我们使用DP思想,从尾部开始遍历字符串,对于每个字符再遍历它之后的元素,一共有三种状态,当i==j时,令数组为1;当s[i]==s[j]时,我们还要分情况讨论,如果i==j-1,此时直接令数组为2,因为下一个状态i>j;如果i!=j-1,那么f[i][j]=f[i+1][j-1]+2;

最后一种情况是,当两个字符不构成回文子串时,我们选择上一个状态下最大的一端继续前进,

f[i][j]=max(f[i+1][j],f[i][j-1]);

相关推荐
qianbo_insist6 分钟前
Mask R-CNN Fast-ReID 结合
人工智能·算法·cnn
lbb 小魔仙19 分钟前
【Java】基于 Java 的分布式系统实战:分布式锁 + 事务 + 一致性算法,干货满满
java·分布式·算法
uoKent23 分钟前
c++中的初始化列表
数据结构·c++
朔北之忘 Clancy23 分钟前
第一章 顺序结构程序设计(3)
c++·算法·青少年编程·竞赛·教材·考级·讲义
Ethan-D24 分钟前
每日一题#21 二维 DP + 计数类
java·python·算法·leetcode·动态规划
飞Link27 分钟前
微调阶段中的模型自我提升、通用模型蒸馏和数据扩充
人工智能·算法·数据挖掘
共享家952728 分钟前
力扣刷题之路
算法·leetcode·深度优先
alonewolf_9930 分钟前
Redis 7 核心数据结构指南:从基础到实战应用
数据结构·redis·分布式架构
七夜zippoe34 分钟前
Python算法优化实战:时间与空间复杂度的艺术平衡
开发语言·python·算法·贪心算法·动态规划·复杂度
青槿吖35 分钟前
【Java集合通关秘籍】从List到Set:解锁无序不重复的集合魔法✨
java·开发语言·算法