题解 | #判断两个IP是否属于同一子网#

判断两个IP是否属于同一子网

https://www.nowcoder.com/practice/34a597ee15eb4fa2b956f4c595f03218



mask = list(map(int,input().split('.')) )
ip1 = list(map(int,input().split('.')) )
ip2 = list(map(int,input().split('.')) )

def check_mask(m):
    if len(m) != 4:
        return (False,None)
    else:
        for i in m:
            if i<0 or i>255:
                return (False,None)
            
        int32 = m[0]*256**3 + m[1]*256**2 + m[2]*256 + m[3]
        strb = bin(int32)[2:]
        pos1 = strb.rfind('1')
        pos0 = strb.find('0')
        if pos0 - pos1 == 1:
            return (True,int32)
        else:
            return (False,None)

def check_ip(ip):
    if len(ip) != 4:
        return (False,None)
    else:
        for i in ip:
            if i<0 or i>255:
                return (False,None)
                
        int32 = ip[0]*256**3 + ip[1]*256**2 + ip[2]*256 + ip[3]
        return (True,int32)

ret = check_mask(mask)
if not ret[0]:
    print(1)
    exit()
ret1 = check_ip(ip1)
if not ret1[0]:
    print(1)
    exit()
ret2 = check_ip(ip2)
if not ret2[0]:
    print(1)
    exit()

if (ret[1] & ret1[1]) == (ret[1] & ret2[1]):
    print(0)
else:
    print(2)

最后一个没通过
1.255.255.0
187.39.235.7
219.79.189.231

预期输出 1
实际输出 2


全部评论

相关推荐

11-03 14:38
重庆大学 Java
AAA求offer教程:我手都抬起来了又揣裤兜了
点赞 评论 收藏
分享
点赞 评论 收藏
分享
不愿透露姓名的神秘牛友
11-24 20:55
阿里国际 Java工程师 2.7k*16.0
程序员猪皮:没有超过3k的,不太好选。春招再看看
点赞 评论 收藏
分享
评论
点赞
收藏
分享
牛客网
牛客企业服务