LeetCode题解(1170):比较字符串最小字母的出现频次(Python)
发布日期:2021-06-29 19:55:30
浏览次数:3
分类:技术文章
本文共 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 如侵犯您的版权,请留言回复原文章的地址,我们会给您删除此文章,给您带来不便请您谅解!
发表评论
最新留言
关注你微信了!
[***.104.42.241]2024年04月16日 22时48分36秒
关于作者
喝酒易醉,品茶养心,人生如梦,品茶悟道,何以解忧?唯有杜康!
-- 愿君每日到此一游!
推荐文章
数据传输-json的存与读 [laravel]
2019-04-30
vuecli3项目怎么修改title[动态改变]
2019-04-30
使用mybatis操作MySQL中的数据库表1---读取数据
2019-04-30
使用mybatis操作MySQL中的数据库表2---插入数据 以及开启日志
2019-04-30
使用mybatis操作MySQL中的数据库表3---使用工具类简化代码
2019-04-30
[需要继续修改]MongoDB的简介
2019-04-30
ElasticSearch简介
2019-04-30
敏捷开发(Agile),持续集成(Continuous Integration)简介
2019-04-30
CI环境搭建----gitlab的安装配置
2019-04-30
CI环境搭建----Jenkins的安装配置
2019-04-30
CI环境搭建----Maven的安装以及和Jenkins的集成
2019-04-30
CI环境搭建----Tomcat的安装配置
2019-04-30
Spark原理----术语
2019-04-30
Streaming 流式计算的模式
2019-04-30
Spark消费kafka数据的两种方式
2019-04-30
Spark中RDD,Dstream,DataSet,DataFrame简介
2019-04-30
Spark性能调优
2019-04-30
MVC简介
2019-04-30
Java设计模式---代理模式
2019-04-30