【获取最大软件版本号】
Maven 版本号定义,<主版本>.<次版本>.<增量版本>-<里程碑版本>
举例3.1.4-beta 其中,主版本和次版本都是必须的,主版本,次版本,增量版本由多位数字组成,可能包含前导零,里程碑版本由字符串组成。
<主版本>.<次版本>.<增量版本>:基于数字比较
里程碑版本:基于字符串比较,采用字典序
比较版本号时,按从左到右的顺序依次比较。
基于数字比较, 只需比较忽略任何前导零后的整数值 。
输入2个版本号,输出最大版本号。
思路:数组排序,方法一,可以优化为方法二
import re
s1 = input()
s2 = input()
sl1 = re.split(r'[.,-]',s1)
sl2= re.split(r'[.,-]',s2)
l1 = list(map(int,sl1[0:3]))
l2 = list(map(int,sl2[0:3]))
if len(sl1) == 4:
l1.append(sl1[3])
if len(sl2) == 4:
l2.append(sl2[3])
if len(l1) > len(l2):
for i in range(len(l1)):
if i == len(l2) -1 and l1[i] == l2[i]:
print(s1)
break
elif l1[i] > l2[i]:
print(s1)
break
elif l1[i] < l2[i]:
print(s2)
break
else:
continue
if len(l1) < len(l2):
for i in range(len(l2)):
if i == len(l1) -1 and l1[i] == l2[i]:
print(s2)
break
elif l2[i] > l1[i]:
print(s2)
break
elif l2[i] < l1[i]:
print(s1)
break
else:
continue
if len(l1) == len(l2):
for i in range(len(l2)):
if l2[i] > l1[i]:
print(s2)
break
elif l2[i] < l1[i]:
print(s1)
break
else:
continue
else:
print(s1)
方法二
import re
s1 = input()
s2 = input()
sl1 = re.split(r'[.,-]',s1)
sl2= re.split(r'[.,-]',s2)
l1 = list(map(int,sl1[0:3]))
l2 = list(map(int,sl2[0:3]))
if len(sl1) == 4:
l1.append(sl1[3])
if len(sl2) == 4:
l2.append(sl2[3])
d = {s1:l1,s2:l2}
tmp1,tmp2 = sorted(d.items(),key=lambda x:len(x[1]))
print(tmp1,tmp2)
for i in range(len(tmp2[1])):
if i == len(tmp1[1]) -1 and tmp1[1][i] == tmp2[1][i] and len(tmp1[1]) != len(tmp2[1]):
print(tmp2[0])
break
elif tmp1[1][i] > tmp2[1][i]:
print(tmp1[0])
break
elif tmp1[1][i] < tmp2[1][i]:
print(tmp2[0])
break
else:
continue
else:
print(tmp1[0])