LeetCode题解(1170):比较字符串最小字母的出现频次(Python)
发布日期:2021-06-29 19:55:30
浏览次数:4
分类:技术文章
本文共 1543 字,大约阅读时间需要 5 分钟。
题目:(简单)
标签:字符串、数组
解法 | 时间复杂度 | 空间复杂度 | 执行用时 |
---|---|---|---|
Ans 1 (Python) | O ( N × M ) O(N×M) O(N×M) : M为words的长度 | O ( M ) O(M) O(M) : M为words的长度 | 508ms (46.91%) |
Ans 2 (Python) | O ( N × M ) O(N×M) O(N×M) : M为words的长度 | O ( M ) O(M) O(M) : M为words的长度 | 480ms (61.80%) |
Ans 3 (Python) | O ( N l o g M ) O(NlogM) O(NlogM): M为words的长度 | O ( M ) O(M) O(M): M为words的长度 | 72ms (99.16%) |
解法一(哈希表):
def numSmallerByFrequency(self, queries: List[str], words: List[str]) -> List[int]: word_num = [] for word in words: count = collections.Counter(word) word_num.append(count[sorted(count.keys())[0]]) ans = [] for query in queries: count = collections.Counter(query) num = count[sorted(count.keys())[0]] k = 0 for w in word_num: if w > num: k += 1 ans.append(k) return ans
解法二(优化解法一的最小值出现频次计算方法):
def numSmallerByFrequency(self, queries: List[str], words: List[str]) -> List[int]: word_num = [] for word in words: word_num.append(word.count(min(word))) ans = [] for query in queries: num = query.count(min(query)) k = 0 for w in word_num: if w > num: k += 1 ans.append(k) return ans
解法三(优化解法二中的查找方法):
def numSmallerByFrequency(self, queries: List[str], words: List[str]) -> List[int]: words = [word.count(min(word)) for word in words] words.sort() ans = [] for query in queries: num = query.count(min(query)) count = len(words) - bisect.bisect_right(words, num) ans.append(count) return ans
转载地址:https://dataartist.blog.csdn.net/article/details/107108893 如侵犯您的版权,请留言回复原文章的地址,我们会给您删除此文章,给您带来不便请您谅解!
发表评论
最新留言
感谢大佬
[***.8.128.20]2024年04月07日 20时40分41秒
关于作者
喝酒易醉,品茶养心,人生如梦,品茶悟道,何以解忧?唯有杜康!
-- 愿君每日到此一游!
推荐文章
系统架构图
2019-04-30
百度推广工作流程
2019-04-30
事务学习一
2019-04-30
区块链学习一
2019-04-30
项目管理ITTO(一张图梳理49个过程)
2019-04-30
思考的整理术
2019-04-30
DMZ-demilitarized zone 隔离区
2019-04-30
沃学设计图
2019-04-30
网站栏目
2019-04-30
Dojo
2019-04-30
OAuth 2.0学习
2019-04-30
军师旅团营连排班各有多少人
2019-04-30
DotNet NB 学习公众号
2019-04-30
WCF传递Stream时,同时传递其它参数的问题
2019-04-30
abp vNex
2019-04-30
关闭页面前js提示
2019-04-30
window.open关闭后刷新父页面
2019-04-30
ajax异步提交修改按钮文字
2019-04-30
draw.io
2019-04-30