Python:每日一题 91
- 2017-11-27 14:46:00
- 六月
- 来源:
- http://bbs.fishc.com/thread-95897-1-1.html
- 转贴 660
我们知道英文字符A~Z从外观上看,有左右对称的如AM等,也有上下对称的如BK等,也有旋转180度重合的,也称作旋转对称如SN等,也有符合前面三种的称为全对称,现在给出一个字符串,统计出各种对称和非对称的字符数量。注对于全对称的字符就不再计入前三种对称中了。字符串中有重复的字符则都计算在内,如有两个W,则记为左右对称字符2个。
- >>> str1 = 'WEFNKDSPHOFGMAFW'
- >>> StrCount(str1)
- 字符串中共有左右对称字符4个,上下对称字符3个,旋转对称字符2个,全对称字符2个,其他字符5个。
我的程序:
- def StrCount(str1):
- group = ['AMTUVWY', 'BCDEK', 'NSZ', 'HIOX']
- count = [0] * 5
- for i in str1:
- for j in range(len(group)):
- if i in group[j]:
- count[j] += 1
- break
- else:
- count[4] += 1
- print('字符串中共有左右对称字符%d个,上下对称字符%d个,旋转对称字符%d个,全对称字符%d个,其他字符%d个。'%tuple(count))
发表评论