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

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

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

改了好多次,说一下需要注意的坑。

1.

IP地址和子网掩码都应该严格遵循"{数字}.{数字}.{数字}.{数字}"的格式,需要先检测是否是这个格式。

比如"19..0."就不是。

2.

IP地址可以同时是【五类IP地址(ABCDE)】和【私有IP地址】,需要分别独立检查。

3.

对于一条地址信息,它的【IP地址】和【子网掩码】只要有一个不合法,地址信息就标为错误。

题目要求输出的第6项"错误IP或错误子网掩码的数量",实际上指的就是错误的【地址信息】的数量。

同一条地址信息如果【IP地址】和【子网掩码】都错误,不要重复计数。

4.

IP地址如果是"0.*.*.*"和"127.*.*.*",就直接跳过这条地址信息,不要用来计数。

5.

子网掩码的二进制表示需要补足到8位。

比如子网掩码"255.255.32.0",二进制表示应为"11111111.11111111.00100000.00000000",所以它是非法的。

import sys

# 检查五类IP地址和私有IP地址
def checkIP(s: str):
    ls = s.split('.')
    # 格式错误
    if (not all(item.isdigit() for item in ls)) or len(ls) != 4:
        return False
    ls = list(map(int, ls))
    # 非法IP地址
    if not all(0 <= item <= 255 for item in ls):
        return False
    # 0和127开头的IP地址直接忽略
    if ls[0] in [0, 127]:
        return -1
    # 判断ABCDE五类
    result = 0
    if 1 <= ls[0] <= 126:
        result = 2
    elif 128 <= ls[0] <= 191:
        result = 4
    elif 192 <= ls[0] <= 223:
        result = 6
    elif 224 <= ls[0] <= 239:
        result = 8
    elif 240 <= ls[0] <= 255:
        result = 10
    # 判断私有。1私有,0非私有。
    if ls[0] == 10:
        result += 1
    elif (ls[0] == 172) and (16 <= ls[1] <= 31):
        result += 1
    elif (ls[0] == 192) and (ls[1] == 168):
        result += 1
    return result


# 检查子网掩码是否合法
def checkMask(s: str):
    ls = s.split('.')
    if (not all(item.isdigit() for item in ls)) or len(ls) != 4:
        return False
    ls = list(map(int, ls))
    check = ""
    # 每一个二进制值都需要补到8位
    for item in ls:
        check += bin(item)[2:].rjust(8, '0')
    check_num = int(check[0])
    if check_num != 1:
        return False
    cnt = 0
    for char in check:
        cnt += check_num ^ int(char)
        check_num = int(char)
    if cnt != 1:
        return False
    else:
        return True


A_count, B_count, C_count, D_count, E_count, ErrorIPMask_count, privateIP_count = (
    0,
    0,
    0,
    0,
    0,
    0,
    0,
)


def output(s: str):
    global A_count, B_count, C_count, D_count, E_count, ErrorIPMask_count, privateIP_count
    ss = s.strip('\n').split('~')
    if len(ss) != 2:
        e = False
    else:
        e = True
    c_0 = checkIP(ss[0])
    c_1 = checkMask(ss[1])
    if c_0 == -1:
        pass
    elif (c_0 == False) or (c_1 == False) or (e == False):
        ErrorIPMask_count += 1
    elif c_0 > 0:
        if c_0 & 1 == 1:
            privateIP_count += 1
        if c_0 >> 1 == 1:
            A_count += 1
        elif c_0 >> 1 == 2:
            B_count += 1
        elif c_0 >> 1 == 3:
            C_count += 1
        elif c_0 >> 1 == 4:
            D_count += 1
        elif c_0 >> 1 == 5:
            E_count += 1


for line in sys.stdin:
    output(line)

print(f'{A_count} {B_count} {C_count} {D_count} {E_count} {ErrorIPMask_count} {privateIP_count}')

全部评论

相关推荐

02-12 20:22
重庆大学 Java
字节暑期刚入职四天,因为是年前,所以很多正职都放假走了,也就没有给我分配mt,然后有一个老哥在我来的时候给我发了一个landing手册,然后还有关于部门业务的白皮书,还有一些业务代码。然后本人是java面的,进来第一次接触go语言&nbsp;前面几天熟悉了一下go的语法和go的框架,可以读但是还不太会写,然后业务白皮书也看的很头疼,包括landing手册里要了解的很多东西说实话我看文档真的快看死了,一个嵌套一个,问题是我还完全不知道咋用这个我了解的东西,还有就是那个项目代码,那个老哥喊我去写写单测,熟悉一下go的语法,但也进行的很困难(这是我第一段实习,之前都是springboot那一套,真不太熟悉这个)想问问大家的建议,就是我从现在开始到在开年回来之前应该做些什么,我目前就一个想法&nbsp;就是复现一个landing手册上的go框架小项目&nbsp;就是相当于帮自己锻炼锻炼怎么写go&nbsp;或者各位大佬有没有更好的锻炼go语法的建议还有就是大家都在说vibe&nbsp;coding,那我应该怎么锻炼自己使用ai的能力,感觉我除了给一些需求然后它给我生成代码,好像就没别的用法了,那些什么工作流、拆解、skill啥的都不知道从哪一个地方开始,包括我现在正在实习,不知道精力该怎么分配,去网上想找找关于agent开发的一些学习流程,说实话,众说纷纭,有的是从python开始打基础然后系统学那些rag&nbsp;prompt&nbsp;langchain&nbsp;mcp等等,有的是说直接找一个github上的ai项目然后反复问ai,我确实有点迷茫,恳求各位大佬能留下你们宝贵的建议,我一定认真反复深刻学习有一说一&nbsp;我觉得字节饭挺好吃的!
Jasonnnnnn...:直接把项目代码喂给AI然后让它帮你分析,如果组里已经有一些流程图总结的话最好,没有的话自己画一个 Go的话其实只要把基础语法搞明白就行了,项目里很多都是直接让ai帮你写好然后自己稍微改下,不用学的特别深 ai的话,可以自己写一些md文件来搞点小东西,但除非你打算转算法,否则不用把rag langchain学的特别深,了解下就行了
字节跳动公司福利 1371人发布
点赞 评论 收藏
分享
哞客37422655...:高端人士品鉴简历给到顶级,先投递试试。别着急给自己转测开的评价
点赞 评论 收藏
分享
评论
点赞
收藏
分享

创作者周榜

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