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个。

  1. >>> str1 = 'WEFNKDSPHOFGMAFW'
  2. >>> StrCount(str1)
  3. 字符串中共有左右对称字符4个,上下对称字符3个,旋转对称字符2个,全对称字符2个,其他字符5个。
复制代码


我的程序:
  1. def StrCount(str1):
  2.     group = ['AMTUVWY', 'BCDEK', 'NSZ', 'HIOX']
  3.     count = [0] * 5
  4.     for i in str1:
  5.         for j in range(len(group)):
  6.             if i in group[j]:
  7.                 count[j] += 1
  8.                 break
  9.         else:
  10.             count[4] += 1
  11.     print('字符串中共有左右对称字符%d个,上下对称字符%d个,旋转对称字符%d个,全对称字符%d个,其他字符%d个。'%tuple(count))
复制代码
发表评论
评论通过审核后显示。