题目:
解析:
代码:
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
相关推荐
蒋星熠2 小时前
Flutter跨平台工程实践与原理透视:从渲染引擎到高质产物小欣加油2 小时前
leetcode 面试题01.02判定是否互为字符重排3Cloudream2 小时前
LeetCode 003. 无重复字符的最长子串 - 滑动窗口与哈希表详解王璐WL3 小时前
【c++】c++第一课:命名空间空白到白3 小时前
机器学习-聚类索迪迈科技3 小时前
java后端工程师进修ing(研一版 || day40)zzzsde4 小时前
【数据结构】队列芒克芒克4 小时前
LeetCode 面试经典 150 题:删除有序数组中的重复项(双指针思想解法详解)青 .4 小时前
数据结构---二叉搜索树的实现MChine慕青5 小时前
顺序表与单链表:核心原理与实战应用