题解 | #识别有效的IP地址和掩码并进行分类统计#

识别有效的IP地址和掩码并进行分类统计

https://www.nowcoder.com/practice/de538edd6f7e4bc3a5689723a7435682

感觉应该是最短的代码了 自己写出来的纪念下
A,B,C,D,E,I,P=0,0,0,0,0,0,0

def ill(s): #判断掩码是否非法 非法返回true 跳出循环
    if ('0' not in s) or ('1' not in s):
        return True
    for i in range(len(s)):
        if s[i]=='0':
            for each in s1[i:]:
                if each != '0':
                    return True
                
while True:
    try:
        s=list(map(str,input().split('~')))
        b,a=[],[]
        s1=''
        
        for each in s:
            b.append(list(map(str,each.split('.'))))
        if b[0][0]=='0' or b[0][0]=='127':
            continue
        if '' in b[0] or '' in b[1]:
            I+=1
            continue
        for each in s: 
            a.append(list(map(int,each.split('.'))))
        for i in range(len(a[1])):
            s1+=bin(a[1][i])[2:].rjust(8,'0') #右对齐补零避免把类似255.255.255.32的掩码判断为合法
        if ill(s1):
            I+=1
            continue
            
        if [1,0,0,0]<=a[0]<=[126,255,255,255]:
                A+=1
        elif [128,0,0,0]<=a[0]<=[191,255,255,255]:
                B+=1
        elif [192,0,0,0]<=a[0]<=[223,255,255,255]:
                C+=1
        elif [224,0,0,0]<=a[0]<=[239,255,255,255]:
                D+=1
        elif [240,0,0,0]<=a[0]<=[255,255,255,255]:
                E+=1
        if [10,0,0,0]<=a[0]<=[10,255,255,255] or [172,16,0,0]<=a[0]<=[172,3,255,255] or [192,168,0,0]<=a[0]<=[192,168,255,255]:
                P+=1
    except:
        break
print(A,B,C,D,E,I,P)    


#华为#
全部评论

相关推荐

找个工作&nbsp;学历是要卡的&nbsp;要求是高的&nbsp;技能不足是真的&nbsp;实习经验是0的&nbsp;简历无处可写是事实的&nbsp;钱不好赚是真的&nbsp;想躺平又不敢躺&nbsp;也不甘心躺&nbsp;怕自己的灵感和才华被掩埋甚至从未被自己发现&nbsp;又质疑自己是否真正有才华
码农索隆:你现在啊,你心里都明白咋回事,但是你没办法改变现状,一想到未来,你又没有信心狠下心来在当下努力。 得走出这种状态,不能一直困在那里面,哪不行就去提升哪,你一动不动那指定改变不了未来,动起来,积少成多才能越来越好
点赞 评论 收藏
分享
仁者伍敌:难怪小公司那么挑剔,让你们这些大佬把位置拿了
点赞 评论 收藏
分享
评论
6
3
分享

创作者周榜

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