PAT 1042字符统计 1057 数零壹 Python版(Counter计数)

本文介绍了解决两个字符串处理问题的方法:一是统计给定字符串中出现频率最高的字母,并以小写字母形式输出;二是将字符串中字母对应的数值相加,转换为二进制并统计其中0和1的数量。通过使用Python的Counter计数和排序技巧,文章提供了简洁高效的代码实现。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

这两题都是用了字符串和Couter计数,写一块了。

1042 题意:

输入一串字符串,有任意字符。统计字符串中出现次数最多的字母,统计时不用区分大小写,但是输出要小写字母。

思路:

  • 直接用 Counter 计数
  • 主要问题是排序,按次数从大到小排序,如果有并列,就输出字母序小的,也就是说一个关键词从大到小,一个关键词从小到大,可以把先数字取负,然后按升序排列,后得到的结果正是所需的数字从大到小,字母从小到大。

输入:
This is a simple TEST. There ARE numbers and other symbols 1&2&3…
输出:
e 7

import string
from collections import Counter

pat = string.ascii_uppercase + string.ascii_lowercase
mystr = input()
mystr = [ch.lower() for ch in mystr if ch in pat]  # 把所有字母提取出来

counts = Counter(mystr)
ans = sorted(counts.items(), key=lambda x:(-x[1], x[0]))   # 主要体现在这
print(ans[0][0], ans[0][1])

1057 题意:

给定一串字符串,规定英文字母 a-z (不分大小写)对应1-26,问字符串中所有字母对应数的和,转为二进制后有多少个 0 和 1 。

思路:

  • 打表得到字典。
  • 得到 sum 之后通过 bin()函数直接转化。
  • 最后用 Counter 计数
import string
from collections import Counter

lower = string.ascii_lowercase
mystr = input().lower()
mystr = [ch for ch in mystr if ch in lower]  # 把字母提取出来

dic = dict()        
for i in range(1, 27):   #  得到字典 a-1 
    dic[chr(i+96)] = i

sum = 0
for ch in mystr:
    sum += dic[ch]

if sum == 0:   # 值得注意的是,如果sum=0,Counter计数时,0的个数会为1,不符合实际情况,所以要特判
    print(0, 0)
else:
    ans = bin(sum)[2:]  #转化为二进制时开头是 0b
    counts = Counter(ans)
    print(counts['0'], counts['1'])
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值