题目:
解析:
代码:
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
相关推荐
smj2302_796826526 小时前
解决leetcode第3943题递增后的数对数量炽烈小老头7 小时前
【每天学习一点算法 2026/05/25】矩阵中的最长递增路径叁散7 小时前
实验报告:5G 仿真环境与基本链路模拟从负无穷开始的三次元代码生活8 小时前
算法零碎灵感点分享染指11108 小时前
9.LangChain框架(实现RAG)大数据三康8 小时前
在spyder进行的遗传算法练习Gene_20228 小时前
轮式底盘的微分平坦吴佳浩9 小时前
现代多模态大模型的核心基础:Unified Self-Attention小小编程路10 小时前
C++ 常用逻辑运算符Hali_Botebie10 小时前
两种子词分词算法BPE (Byte-Pair Encoding) 和Unigram 区别
