【python challenge】Level2

分析

题目说的是识别字符,字符可能在图片的书上,可能在页面的源码里面。机智的我马上按了个F12,发现一大堆混乱的字符,要求就是从中找出稀有的字符,智商感人的我还对所有出现字符的次数排了个序~~~,其实只要判断是a-z的字符把他拼起来就是了。

领略下我的智商吧~

dict_count = {}
for ind, ch in enumerate(mess_str):
    if dict_count.get(ord(ch)):
        dict_count[ord(ch)] += 1
    else:
        dict_count[ord(ch)] = 1

heap = []
char_str = ""
for ch_int, count in dict_count.items():
    heapq.heappush(heap, (count, ch_int))
    # 下面输出了结果,感觉就是字符拼起来就好才加的~
    if ord('a') <= ch_int <= ord('z'): 
        char_str += chr(ch_int)

print(char_str)
res = [heapq.heappop(heap) for i in range(len(heap))]
print(res)
res_str = "".join(chr(va[1]) for va in res)
print(res_str)

Learn

智商感人也是有好处的,heapq模块技能点Get!!!
heapq:python中的堆模块,可以很容易的实现优先队列,求最大N个元素,最小N个元素。嘛,这本来就是堆的最简单应用

基本接口:
  • heappush : 进堆
  • heappop : 最小值出堆
  • heappushpop : 新元素进堆,然后再最小值出堆,相当于前面两个接口的组合
  • heapify : 把一个列表转化成堆
  • heapreplace : 先出堆,再进堆,保持堆大小,和pushpop顺序不一样哦,相比分步调用更有效率
  • nlargest : 返回最大N个元素
  • nsmallest : 返回最小N个元素
  • merge : 这就有点复杂了,merge的工作是合并多个可枚举的数据,并维持堆属性。有3个参数(*iterables, key=None, reverse=None)其中key和reverse是在3.5之后才添加的。
    • key:是个函数返回用于对列表数据处理返回用于比较的值
    • reverse:是个布尔值,如果设置为true那么所有比较结果将反转。

ref:
[-] python heapq文档

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值