|
发表于 2016-11-17 23:10:13
|
显示全部楼层
本帖最后由 人zai旅途 于 2016-11-17 23:48 编辑
str1 = '''ABSaDKSbRIHcRHGcdDIF'''
countA = 0 # 统计前边的大写字母---变量初始化为0
countB = 0 # 统计小写字母 ---变量初始化为0
countC = 0 # 统计后边的大写字母---变量初始化为0
length = len(str1) # 求出字符串str1的长度
for i in range(length): # 长度是数字,range(length)会产生一个序列,i遍历序列,i将作为下标,来访问str1的每一个字符元素
if str1[i] == '\n': # 在上面for 循环背景下,str1[i]代表每一个字符,如果是换行符,暂不处理,continue表示不再执行剩余语句,重新开始判断条件是否成立
continue
"""
|如果str1[i]是大写字母:
|-- 如果已经出现小写字母:
|-- -- 统计后边的大写字母
|-- 如果未出现小写字母:
|-- -- 清空后边大写字母的统计
|-- -- 统计前边的大写字母
""" # """表示注释,其实给出了解题思路
if str1[i].isupper(): # 字符.isupper()表示判断是否大写,结果为True或False,见14讲,字符串的奇葩内置方法
if countB: # 条件语句,countB一开始被赋值为0,条件不成立,执行else后面的语句
countC += 1 # 如果countB不等于0,条件成立,则countC=countC+1,表示统计一次后边的大写字母
else:
countC = 0 # countC赋值0,就是清空后边大写字母的统计
countA += 1 # countC=countC+1,表示统计一次后边的大写字母
"""
|如果str1[i]是小写字母:
|-- 如果小写字母前边不是三个大写字母(不符合条件):
|-- -- 清空所有记录,重新统计
|-- 如果小写字母前边是三个大写字母(符合条件):
|-- -- 如果已经存在小写字母:
|-- -- -- 清空所有记录,重新统计(出现两个小写字母)
|-- -- 如果该小写字母是唯一的:
|-- -- -- countB记录出现小写字母,准备开始统计countC
"""
if str1[i].islower(): # 字符.islower()表示判断是否大写,结果为True或False,见14讲,字符串的奇葩内置方法
if countA != 3: # 条件语句,countA 不等于3,即小写字母前边不是三个大写字母,则后面三个统计均赋值为0,即清空所有记录,重新统计
countA = 0
countB = 0
countC = 0
else: # 否则,countA 等于3的时候
if countB: # 如果已经存在小写字母,也就是countB不等于0(也就是条件为True,条件成立)
countA = 0
countB = 0
countC = 0 # 后面三个统计均赋值为0,即清空所有记录,重新统计
else: #否则,
countB = 1 # 统计一次小写字母,即 countB = 1
countC = 0
target = i # 密码所处位置对应的下标,用i来赋值,符合条件的i用来定位密码字符
"""
|如果前边和后边都是三个大写字母:
|-- 如果后边第四个字母也是大写字母(不符合条件):
|-- -- 清空记录B和C,重新统计
|-- 如果后边仅有三个大写字母(符合所有条件):
|-- -- 打印结果,并清空所有记录,进入下一轮统计
"""
if countA == 3 and countC == 3: # 前边和后边都是三个大写字母,即统计大写字母数量的变量值为3
if i+1 != length and str1[i+1].isupper(): # i+1 != length,是为了规定i不能是倒数第2个字符,str1[i+1].isupper()表示i后边是大写字母
countB = 0
countC = 0 # 清空记录B和C,重新统计
else: #否则
print(str1[target], end='') #打印目标位置的字符,且字符紧挨着,end='',表示用''代替'\n',end='\n'是print()函数的默认参数,表示输出内容会默认换行
countA = 3
countB = 0
countC = 0 |
评分
-
查看全部评分
|