题目:
解析:
代码:
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
相关推荐
承渊政道13 分钟前
【动态规划算法】(完全背包问题从状态定义到空间优化)超级大福宝15 分钟前
【力扣48. 旋转图像】超好记忆版 + 口诀爱写代码的倒霉蛋16 分钟前
2023年天梯赛L1-8apollowing29 分钟前
启发式算法WebApp实验室:从搜索策略到群体智能的能力进阶(上)生物信息与育种1 小时前
黄三文院士领衔植物星球计划(PLANeT)发表Cellaini_lovee1 小时前
WSN 四大经典无需测距定位算法人道领域1 小时前
【LeetCode刷题日记】掌握二叉树遍历:栈实现的三种绝妙方法北冥湖畔的燕雀1 小时前
深入解析Linux信号处理机制阿Y加油吧1 小时前
二刷 LeetCode:动态规划经典双题复盘上弦月-编程1 小时前
C语言指针超详细教程——从入门到精通(面向初学者)
