题目:
![]()
解析:
![]()
代码:
public 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;}
动态规划子数组系列一>环绕字符串中唯一的子字符串
2025/9/22 21:59:31
来源:https://blog.csdn.net/robin_suli/article/details/144318192
浏览:
次
关键词:动态规划子数组系列一>环绕字符串中唯一的子字符串
版权声明:
本网仅为发布的内容提供存储空间,不对发表、转载的内容提供任何形式的保证。凡本网注明“来源:XXX网络”的作品,均转载自其它媒体,著作权归作者所有,商业转载请联系作者获得授权,非商业转载请注明出处。
我们尊重并感谢每一位作者,均已注明文章来源和作者。如因作品内容、版权或其它问题,请及时与我们联系,联系邮箱:809451989@qq.com,投稿邮箱:809451989@qq.com
热文排行
- 电力物联网的电力监控系统
- `git restore` 和 `git checkout` 用于丢弃工作区的改动, `git switch` 和 `git checkout` 用来切换分支
- 《警世贤文》摘抄:处人篇、受恩篇、宽人篇、听劝篇、劝善篇(多读书、多看报、少吃零食多睡觉)
- Android显示系统(08)- OpenGL ES - 图片拉伸
- Vmess协议是什么意思? VLESS与VMess有什么区别?
- 三元组抽取在实际应用中如何处理语义模糊性?
- WPS将文字文档朗读
- 使用 Docker 在 Alpine Linux 下部署 Caddy 服务器
- Rust Web框架怎么选?
- Vue.js 项目部署全解析:从开发到上线的关键旅程题