wl2678287564 发表于 2022-10-10 21:20:38

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)

Twilight6 发表于 2022-10-11 10:31:38


这个代码就是判断版本号高低的,其实核心代码就是这段:

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]
查看完整版本: 28讲的课后作业这两个代码分别是什么原理