python怎么解决有序字符数问题

这篇文章主要介绍“python怎么解决有序字符数问题”的相关知识,小编通过实际案例向大家展示操作过程,操作方法简单快捷,实用性强,希望这篇“python怎么解决有序字符数问题”文章能帮助大家解决问题。

有序字符数

1.1  菜鸡解法

from collections import OrderedDict

def ordered_count(input):   counts = OrderedDict()   for char in input:       counts[char] = counts.get(char, 0) + 1
  return list(counts.items())

1.2  高手解法1

from collections import OrderedDict, Counter
class OrderedCounter(Counter, OrderedDict):    pass    def ordered_count(seq):     m=OrderedCounter(seq)     return list(OrderedCounter(seq).items())

1.3 高手解法2

from collections import Counter
def ordered_count(input):    return list(Counter(input).items())

1.4 点评

这道题因为要考虑有序,就是按照字符串里面的字符顺序,同时要统计字符出现的次数。高手解法1非常巧妙,里面两个类的继承,同时继承了collection 模块里面的OrderedDict和Counter两个子类。很秒!

缩写双字名称答案

2.1 高手解法1

def abbrevName(name):    return '.'.join(w[0] for w in name.split()).upper()

2.2 高手解法2

abbrevName = lambda name: ".".join(e[0].upper() for e in name.split())

2.3 点评

几种高手的解法都是利用列表推导列表进行快速处理,然后用字符串自带upper()函数进行全大写。建议要熟悉常用的内置函数,比如:

''.lower()''.upper()''.count()''.startswith()''.capitalize()

关于“python怎么解决有序字符数问题”的内容就介绍到这里了,感谢大家的阅读。如果想了解更多行业相关的知识,可以关注蜗牛博客行业资讯频道,小编每天都会为大家更新不同的知识点。

免责声明:本站发布的内容(图片、视频和文字)以原创、转载和分享为主,文章观点不代表本网站立场,如果涉及侵权请联系站长邮箱:niceseo99@gmail.com进行举报,并提供相关证据,一经查实,将立刻删除涉嫌侵权内容。

评论

有免费节点资源,我们会通知你!加入纸飞机订阅群

×
天气预报查看日历分享网页手机扫码留言评论Telegram