Python中字典的一些简单练习

一,用户输入一个数字,判断输入的各个数字重复了多少次:

方法一:

num=input('>>>')
d={}
for i in num:
    d[i]=d.setdefault(i,0)+1
print(d)

方法二:

num=input('>>>')
d={}
for i in num:
    if i not in d.keys():
       d[i]=0  #若发现i不在字典的kv对中赶紧添加一个为i的key并设置其缺省值为0
    d[i]+=1
print(d)

方法三:

from collections import defaultdict
num=input('>>>')
d=defaultdict(int)
for i in num:
    d(i)+=1
print(d)

方法四:

num=input('>>>')
d={}
for i in num:
    d[i]=d.get(i,0)+1
print(d)

二.随机从范围[-1000,1000]中取出100个数,升序打印所有不同数字及其出现次数:

import random
d={}
lst=list(random.randint(-1000,1000) for i in range(100))
for j in lst:
    d[j]=d.get(j,0)+1
print(sorted(d))

     注意其中的sorted的用法,输入sorted?  自己看一下

三.从字符组'abcdefghijklmnopqrstuvwxyz'中随机抽取两个字母组成字符串,共挑选一百个,降序输出所有不同的     字符串及其重复次数.

方法一:

import random
s='abcdefghijklmnopqrstuvwxyz'
d={}
for i in range(100):
    ins=''.join(random.sample(s,2))
    d[ins]=d.get(ins,0)+1
for j in reversed(sorted(d.keys()):
    print(j,end=' ')
    print('Repeat {} times'.format(d[j]))

    

此方法中我们应知道sample取出的元素是一口气取出的两个,如果要取出'mm','nn'等类型的就取不出来了,但思路是正确的.

方法二:

import random
s='abcdefghijklmnopqrlstuvwxyz'
d={}
lst=[]
for _ in range(100):
    lst.append(''.join(random.choice(s) for _ in range(2)))
for i in lst:
    d[i]=d.get(i,0)+1
print(sorted((d.items()),reverse=True)


你可能感兴趣的:(Python中字典的一些简单练习)