LeetCode题解(1163):按字典序排在最后的子串(Python)
发布日期:2021-06-29 19:58:25
浏览次数:3
分类:技术文章
本文共 795 字,大约阅读时间需要 2 分钟。
题目:(困难)
标签:字符串
解法 | 时间复杂度 | 空间复杂度 | 执行用时 |
---|---|---|---|
Ans 1 (Python) | O ( N 2 ) O(N^2) O(N2) | O ( 1 ) O(1) O(1) | 3920ms (18.31%) |
Ans 2 (Python) | O ( N 2 ) O(N^2) O(N2) | O ( 1 ) O(1) O(1) | 476ms (56.34%) |
Ans 3 (Python) |
解法一(暴力解法):
class Solution: def lastSubstring(self, s: str) -> str: ans = "" for i in range(len(s)): ans = max(ans, s[i:]) return ans
解法二(解法一优化):
测试用例中有一个特别多连续的a的用例
class Solution: def lastSubstring(self, s: str) -> str: ans = s for i in range(1, len(s)): if s[i] != s[i-1]: # 如果子串的开头和前一个字符相等的话,一定不会是解 for j in range(len(s) - i): if ans[j] < s[i + j]: ans = s[i:] break elif ans[j] > s[i + j]: break return ans
转载地址:https://dataartist.blog.csdn.net/article/details/108096374 如侵犯您的版权,请留言回复原文章的地址,我们会给您删除此文章,给您带来不便请您谅解!
发表评论
最新留言
能坚持,总会有不一样的收获!
[***.219.124.196]2024年04月27日 09时06分20秒
关于作者
喝酒易醉,品茶养心,人生如梦,品茶悟道,何以解忧?唯有杜康!
-- 愿君每日到此一游!
推荐文章
JavaScript 闭包
2019-04-30
作用域链的理解
2019-04-30
JavaScript原型,原型链
2019-04-30
什么是事件代理
2019-04-30
Javascript如何实现继承
2019-04-30
谈谈This对象的理解
2019-04-30
事件模型
2019-04-30
new操作符具体干了什么呢?
2019-04-30
Ajax原理
2019-04-30
模块化开发
2019-04-30
异步加载JS的方式有哪些
2019-04-30
那些操作会造成内存泄漏
2019-04-30
XML和JSON的区别?
2019-04-30
浅谈webpack
2019-04-30
AMD 和 Commonjs
2019-04-30
常见web安全及防护原理
2019-04-30
设计模式看这里就够了
2019-04-30
为什么要有同源限制
2019-04-30
javascript 定义对象的方式
2019-04-30