一,用户输入一个数字,判断输入的各个数字重复了多少次:
方法一:
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)