|
马上注册,结交更多好友,享用更多功能^_^
您需要 登录 才可以下载或查看,没有账号?立即注册
x
一、
- def funX():
- x = 5
- def funY():
- nonlocal x
- x += 1
- return x
- return funY
- a = funX()
- print(a())
- print(a())
- print(a())
复制代码
為什麼以上代碼是打印?
6
7
8
看了小甲魚的解釋,沒看懂,有人能更詳細解釋嗎?
二、
- str1 = '''ABSaDKSbRIHcRHGcdDIF'''
- countA = 0 # 统计前边的大写字母
- countB = 0 # 统计小写字母
- countC = 0 # 统计后边的大写字母
- length = len(str1)
- for i in range(length):
- if str1[i] == '\n':
- continue
- """
- |如果str1[i]是大写字母:
- |-- 如果已经出现小写字母:
- |-- -- 统计后边的大写字母
- |-- 如果未出现小写字母:
- |-- -- 清空后边大写字母的统计
- |-- -- 统计前边的大写字母
- """
- if str1[i].isupper():
- if countB:
- countC += 1
- else:
- countC = 0
- countA += 1
- """
- |如果str1[i]是小写字母:
- |-- 如果小写字母前边不是三个大写字母(不符合条件):
- |-- -- 清空所有记录,重新统计
- |-- 如果小写字母前边是三个大写字母(符合条件):
- |-- -- 如果已经存在小写字母:
- |-- -- -- 清空所有记录,重新统计(出现两个小写字母)
- |-- -- 如果该小写字母是唯一的:
- |-- -- -- countB记录出现小写字母,准备开始统计countC
- """
- if str1[i].islower():
- if countA != 3:
- countA = 0
- countB = 0
- countC = 0
- else:
- if countB:
- countA = 0
- countB = 0
- countC = 0
- else:
- countB = 1
- countC = 0
- target = i
- """
- |如果前边和后边都是三个大写字母:
- |-- 如果后边第四个字母也是大写字母(不符合条件):
- |-- -- 清空记录B和C,重新统计
- |-- 如果后边仅有三个大写字母(符合所有条件):
- |-- -- 打印结果,并清空所有记录,进入下一轮统计
- """
- if countA == 3 and countC == 3:
- if i+1 != length and str1[i+1].isupper():
- countB = 0
- countC = 0
- else:
- print(str1[target], end='')
- countA = 3
- countB = 0
- countC = 0
复制代码
我發現在最後面的地方
else:
print(str1[target], end='')
countA = 3
countB = 0
countC = 0
如果把
countA = 3
改成
countA = 0
或是乾脆把
countA = 3
countB = 0
countC = 0
都拿掉
也會得到一樣的結果,請問這麼做對代碼會有什麼影響呢?
而小甲魚加上那段代碼的理由是...?
a=funx()就运行了funX(),所以x=5,这时a的值就变成了funY,和funX()没有了一点关系
其实就相当于:
- x=5
- def funY():
- x+=1
- reuturn x
- def funX():
- return funY
- a=funx() # 此时的a是返回值funY
- a() # 运行的是funY,x没有被重置
- a() # 同理
- a() # 同理
复制代码
|
|