题解 | #判断两个IP是否属于同一子网#
判断两个IP是否属于同一子网
https://www.nowcoder.com/practice/34a597ee15eb4fa2b956f4c595f03218
# 格式非法,每一段在0-255之间
# 是否同一子网
flag = 4
yanma = input().split(".")
yanma = [int(i) for i in yanma]
ip1 = input().split(".")
ip1 = [int(i) for i in ip1]
ip2 = input().split(".")
ip2 = [int(i) for i in ip2]
# 二进制AND运算
res_1 = []
res_2 = []
for i in range(4):
res_1.append(ip1[i] & yanma[i])
res_2.append(ip2[i] & yanma[i])
if res_1 == res_2:
flag = 0
else:
flag = 2
# 判断是不是合法字符
tuples = (yanma, ip1, ip2)
# 大于255
for ite in tuples:
for i in ite:
if i > 255 or i<0:
flag = 1
# 把掩码转为二进制
for index, value in enumerate(yanma):
k = bin(value)[2:]
count = 8 - len(k)
k = "0" * count + k
yanma[index] = k
yanma_str = "".join(yanma) # 列表组合成字符串
# 合法的掩码是全1后面接全0,不能有穿插的情况,可以比较前后字符有多少次不同,只有一次不同是合法的
count = 0 # 记录前后字符不同的数量
k = yanma_str[0] # 给k赋初始值
for i in yanma_str: # 遍历比较
if i != k:
count += 1 # 如果不同,就+1
k = i
if count > 1:
flag = 1
print(flag)