题目:
解析:
代码:
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
相关推荐
im_AMBER2 小时前
算法笔记 09凯芸呢2 小时前
Java中的数组(续)寂静山林2 小时前
UVa 1030 Image Is EverythingAI柠檬2 小时前
几种排序算法的实现和性能比较weixin_429630263 小时前
第6章 支持向量机SweetCode3 小时前
C++ 实现大数加法王哈哈^_^3 小时前
【数据集】【YOLO】【目标检测】共享单车数据集,共享单车识别数据集 3596 张,YOLO自行车识别算法实战训推教程。CodeWizard~4 小时前
AtCoder Beginner Contest 430赛后补题大大dxy大大4 小时前
机器学习-KNN算法示例关于不上作者榜就原神启动那件事5 小时前
模拟算法乒乓球
