鱼C论坛

 找回密码
 立即注册
查看: 2156|回复: 1

[已解决]28讲的课后作业这两个代码分别是什么原理

[复制链接]
发表于 2022-10-10 21:20:38 | 显示全部楼层 |阅读模式

马上注册,结交更多好友,享用更多功能^_^

您需要 登录 才可以下载或查看,没有账号?立即注册

x
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[i] != '.':
        x = x * 10 + int(v1[i])
        i += 1
    i += 1
    y = 0
    while j < m and v2[j] != '.':
        y = y * 10 + int(v2[j])
        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[i]
        while i != -1:
            if last != y[i]:
                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[i]
        while i != -1:
            if last != x[i]:
                print("由于替换字符出现冲突,该密文无法解密!")
                flag = -1
                break
   
            i = y.find(each, i+1)
最佳答案
2022-10-11 10:31:38

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

  1. x = 0
  2. while i < n and v1[i] != '.':
  3.     x = x * 10 + int(v1[i])
  4.     i += 1
  5. i += 1
复制代码


而这段代码的作用,就是将版本号每个 "." 点,之前的数进换算成一个数值,然后依次比较对应 . 之前的数值谁大谁小

例如 v1 = 1.39.4      v2 = 1.40.3  第一次执行完这部分的循环,就会分别将 v1 和 v2 中第一个 "." 之前的数字,换算成整形后进行大小比较

即此时比较 v1 第一个点之前的 1 和 v2 第一个点之前的 1 是否能比较出大小,若可以,打印大的变量名,若不行,继续比较后续的版本号

这里因为都为 1 所以就会开始第二次大循环,即判断 第二个 "." 之前 第一个 "." 之后的数值大小,同样的比较规则,继续第三次,第四次循环,知道循环结束

这里第二次大循环比较时 v1 换算后的数值为 39 而 v2 换算为 40 ,所以直接得出 v2 版本 大于 v1,后续的版本号因为位数小,所以不需要再进行比较了

想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复

使用道具 举报

发表于 2022-10-11 10:31:38 | 显示全部楼层    本楼为最佳答案   

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

  1. x = 0
  2. while i < n and v1[i] != '.':
  3.     x = x * 10 + int(v1[i])
  4.     i += 1
  5. i += 1
复制代码


而这段代码的作用,就是将版本号每个 "." 点,之前的数进换算成一个数值,然后依次比较对应 . 之前的数值谁大谁小

例如 v1 = 1.39.4      v2 = 1.40.3  第一次执行完这部分的循环,就会分别将 v1 和 v2 中第一个 "." 之前的数字,换算成整形后进行大小比较

即此时比较 v1 第一个点之前的 1 和 v2 第一个点之前的 1 是否能比较出大小,若可以,打印大的变量名,若不行,继续比较后续的版本号

这里因为都为 1 所以就会开始第二次大循环,即判断 第二个 "." 之前 第一个 "." 之后的数值大小,同样的比较规则,继续第三次,第四次循环,知道循环结束

这里第二次大循环比较时 v1 换算后的数值为 39 而 v2 换算为 40 ,所以直接得出 v2 版本 大于 v1,后续的版本号因为位数小,所以不需要再进行比较了

想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

小黑屋|手机版|Archiver|鱼C工作室 ( 粤ICP备18085999号-1 | 粤公网安备 44051102000585号)

GMT+8, 2024-5-20 07:13

Powered by Discuz! X3.4

© 2001-2023 Discuz! Team.

快速回复 返回顶部 返回列表