PAT1 1071 Speech Patterns

题目大意
我的github

题目大意

给一行字符串,要求字符串里面单词出现次数最多的那个

输入

每组包含一个测试用例,对每个用例都是一行字符串,且长度不超过1048576个字符,以换行结束。
输入至少包含一个字母数字字符,即匹配的单词的字符都应该在集合 [ 0 − 9 ∣ A − Z ∣ a − z ] [0-9|A-Z|a-z] [09AZaz]里面

输出

对每个测试用例,输出出现次数最多的单词和次数,如果有多个,输出字典序最大的那个

解析

使用python的正则表达式即可完成匹配的工作,然后再用字典解决计数问题,最后对结果排序即可。但是要注意的是这题的单词不区分大小写

# -*- coding: utf-8 -*- 
# @Time : 2019/6/29 11:31 
# @Author : ValarMorghulis 
# @File : 1071.py
import re


def solve():
    s = input()
    words = re.findall('[0-9|A-Z|a-z]+', s)
    words = [i.lower() for i in words]
    dic = dict()
    ans, num = "", 0
    for i in words:
        if i not in dic:
            dic[i] = 0
        dic[i] += 1
    ans = sorted([[dic[i], i] for i in dic], key=lambda x: (-x[0], x[1]))
    print(ans[0][1], ans[0][0])


if __name__ == "__main__":
    solve()

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值