题目:
解析:
代码:
javapublic int findSubstringInWraproundString(String ss) { int n = ss.length(); int[] dp = new int[n]; char[] s = ss.toCharArray(); for(int i = 0; i < n; i++) dp[i] = 1; for(int i = 1; i < n; i++){ if(s[i - 1] + 1 == s[i] || (s[i - 1] == 'z' && s[i] == 'a')) dp[i] += dp[i-1]; } //去重:把dp表中的字串重复的,只留最长的字串(hash表来建立映射关系) int[] hash = new int[26]; for(int i = 0; i < n; i++) hash[s[i]-'a'] = Math.max(hash[s[i]-'a'], dp[i]); //返回 int ret = 0; for(int x : hash) ret += x; return ret; }
动态规划子数组系列一>环绕字符串中唯一的子字符串
robin_suli2024-12-08 12:43
相关推荐
何以解忧,唯有..1 小时前
Go语言循环语句详解:for、range与循环控制想吃火锅10052 小时前
【leetcode】88.合并两个有序数组js生成论实验室2 小时前
机器人:一个自主运动的系统Qres8212 小时前
算法复键——树状数组H178535090962 小时前
SolidWorks第四部分_直接实体建模特征9_替换面原理不会就选b2 小时前
算法日常・每日刷题--<二分查找>3绿算技术3 小时前
Mooncake 与绿算ForinnBase GroundPool如何联手打破推理僵局?-森屿安年-3 小时前
63. 不同路径 II老余捞鱼3 小时前
线性回归实战:5步验证你的量化因子是否真有效想吃火锅10054 小时前
【leetcode】121.买卖股票的最佳时机js/c++
