|
|
马上注册,结交更多好友,享用更多功能^_^
您需要 登录 才可以下载或查看,没有账号?立即注册
x
"""
我们知道英文字符A~Z从外观上看,有左右对称的如AM等,也有上下对称的如BK等,
也有旋转180度重合的,也称作旋转对称如SN等,也有符合前面三种的称为全对称,现在给出一个字符串,
统计出各种对称和非对称的字符数量。注对于全对称的字符就不再计入前三种对称中了。字符串中有重复的字符则都计算在内,如有两个W,则记为左右对称字符2个。
"""
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))
def main():
str = 'WEFNKDSPHOFGMAFW'
strcount(str)
main()
下面是IDLE的运行结果:
字符串里面有左右对称字符4个,上下对称字符3个,旋转对称有2个, 全对称子字符2个,其他字符有33个
|
|