题解 | #判断两个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)

全部评论

相关推荐

机械打工仔:有说的你怀疑一下就行了,直接问也太实诚了
点赞 评论 收藏
分享
05-29 09:02
门头沟学院 Java
点赞 评论 收藏
分享
评论
点赞
收藏
分享

创作者周榜

更多
牛客网
牛客网在线编程
牛客网题解
牛客企业服务