题解 | #查找兄弟单词#

查找兄弟单词

https://www.nowcoder.com/practice/03ba8aeeef73400ca7a37a5f3370fe68

aline = input().split()
n = int(aline[0])
# aset = set(aline[1:-2]) # 字典若去重,则用集合(set)
dictionary = aline[1:-2]  # 字典若不去重,则用列表(list)
x = aline[-2]
k = int(aline[-1])
characters = set(x)
freq = {}
for i in characters:
    freq[i] = x.count(i)
brothers = []
for ele in dictionary:
    if ele != x and len(ele) == len(x):
        # 不考虑单词中有重复字符
        # for i in characters:
        #     if i not in ele:
        #         break
        # brothers.append(ele)

        # 考虑单词中有重复字符
        # 方法一:x的字母频次(可存为常量字典)若与ele的字母频次不同,则非兄弟单词
        for i in characters:
            if freq[i] != ele.count(i):
                break
        else:
            brothers.append(ele)

        # 方法二:ele和x分别排序成新的字符串(sorted(x)可存为常量),新字符串相等即为兄弟单词;长单词排序比较耗时
        # if sorted(ele) == sorted(x):
        #     brothers.append(ele)
brothers.sort(key=None, reverse=False)
print(len(brothers))
if k < len(brothers):
    print(brothers[k - 1])

#刷题#
全部评论

相关推荐

不愿透露姓名的神秘牛友
07-11 15:08
点赞 评论 收藏
分享
不愿透露姓名的神秘牛友
07-07 13:46
点赞 评论 收藏
分享
程序员小白条:太晚了,看别人找到实习了才投的话,自己本身就没啥准备,计划太晚咯,只能吞苦果子
点赞 评论 收藏
分享
不愿透露姓名的神秘牛友
07-10 11:45
你不要过来啊啊啊啊啊啊啊
码农索隆:对面:“今天你不面也得面”
点赞 评论 收藏
分享
评论
点赞
收藏
分享

创作者周榜

更多
牛客网
牛客网在线编程
牛客网题解
牛客企业服务