28讲的课后作业这两个代码分别是什么原理
v1 = input("请输入第一个版本号,v1 = ")v2 = input("请输入第二个版本号,v2 = ")
n, m = len(v1), len(v2)
i, j = 0, 0
while i < n or j < m:
x = 0
while i < n and v1 != '.':
x = x * 10 + int(v1)
i += 1
i += 1
y = 0
while j < m and v2 != '.':
y = y * 10 + int(v2)
j += 1
j += 1
if x > y:
print("v1")
break
elif x < y:
print("v2")
break
if x == y:
print("v1 = v2")
plain = input("请输入需要加密的明文:")
x = input("请输入需要替换的字符:")
y = input("请输入将要替换的字符:")
# 加密的代码
if len(x) != len(y):
print("需要替换的字符数量必须跟将要替换的字符数量一致!")
else:
cipher = plain.translate(str.maketrans(x, y))
print("加密后的密文是:" + cipher)
# 检测冲突的代码
# flag 变量标志是否退出检测(只要找到一个冲突,就可以直接退出)
flag = 0
# 如果 x 中存在相同的字符,那么 y 对应下标的字符也应该是相同的
for each in x:
if x.count(each) > 1 and flag == 0:
i = x.find(each)
last = y
while i != -1:
if last != y:
print("由于替换字符出现冲突,该密文无法解密!")
flag = -1
break
i = x.find(each, i+1)
# 如果 y 中存在相同的字符,那么 x 对应下标的字符也应该是相同的
for each in y:
if y.count(each) > 1 and flag == 0:
i = y.find(each)
last = x
while i != -1:
if last != x:
print("由于替换字符出现冲突,该密文无法解密!")
flag = -1
break
i = y.find(each, i+1)
这个代码就是判断版本号高低的,其实核心代码就是这段:
x = 0
while i < n and v1 != '.':
x = x * 10 + int(v1)
i += 1
i += 1
而这段代码的作用,就是将版本号每个 "." 点,之前的数进换算成一个数值,然后依次比较对应 . 之前的数值谁大谁小
例如 v1 = 1.39.4 v2 = 1.40.3第一次执行完这部分的循环,就会分别将 v1 和 v2 中第一个 "." 之前的数字,换算成整形后进行大小比较
即此时比较 v1 第一个点之前的 1 和 v2 第一个点之前的 1 是否能比较出大小,若可以,打印大的变量名,若不行,继续比较后续的版本号
这里因为都为 1 所以就会开始第二次大循环,即判断 第二个 "." 之前 第一个 "." 之后的数值大小,同样的比较规则,继续第三次,第四次循环,知道循环结束
这里第二次大循环比较时 v1 换算后的数值为 39 而 v2 换算为 40 ,所以直接得出 v2 版本 大于 v1,后续的版本号因为位数小,所以不需要再进行比较了
页:
[1]