已知列表data中有若干字符串,要求编写程序,对data中的字符串进行过滤,只输出重复字符不超过一半的字符串
思路:利用collections库中的Counter方法,遍历data列表中的每一个字符串,并把他们存入进一个字符出现次数列表定义一个最大值max存放每一个字符串中出现次数最多的字符,将max与该字符串的长度比较,如果小于它的一半则保留否则就从data列表中删除这个字符串
from collections import Counter
# 1、创建一个包含若干字符串的列表
data = ["www.com", "www.cn", "@www", "@qq.com"] # 根据题意预判结果:只想输出第1, 2, 4个, 第3个w字符的长度为3超过一半
# 2、遍历列表
for d in data:
# 2.1存放字符串中每个字符出现次数的字典
res = Counter(d)
# 2.2遍历字典, 找出字符出现次数最多的那个字符出现的次数
max_len = 0
for key in res:
# print(key, res[key])
if max_len < res[key]:
max_len = res[key]
# print(max_len)
# 2.3将获得的max_len与字符串的长度比较,删除max_len>字符串长度的一半
n = len(d) # 统计每个字符串的长度
if max_len > n / 2:
data.remove(d)
print(data)
运行结果