• 我们在哪一颗星上见过 ,以至如此相互思念 ;我们在哪一颗星上相互思念过,以至如此相互深爱
  • 我们在哪一颗星上分别 ,以至如此相互辉映 ;我们在哪一颗星上入睡 ,以至如此唤醒黎明
  • 认识世界 克服困难 洞悉所有 贴近生活 寻找珍爱 感受彼此

编程测试:牛客华为机试

python知识点 云涯 4年前 (2021-02-07) 2114次浏览

一共104道

第一题

题目描述

请解析IP地址和对应的掩码,进行分类识别。要求按照A/B/C/D/E类地址归类,不合法的地址和掩码单独归类。

所有的IP地址划分为 A,B,C,D,E五类

A类地址1.0.0.0~126.255.255.255;

B类地址128.0.0.0~191.255.255.255;

C类地址192.0.0.0~223.255.255.255;

D类地址224.0.0.0~239.255.255.255;

E类地址240.0.0.0~255.255.255.255

私网IP范围是:

10.0.0.0~10.255.255.255

172.16.0.0~172.31.255.255

192.168.0.0~192.168.255.255

子网掩码为二进制下前面是连续的1,然后全是0。(例如:255.255.255.32就是一个非法的掩码)
注意二进制下全是1或者全是0均为非法
注意:
1. 类似于【0.*.*.*】和【127.*.*.*】的IP地址不属于上述输入的任意一类,也不属于不合法ip地址,计数时可以忽略
2. 私有IP地址和A,B,C,D,E类地址是不冲突的

输入描述:

多行字符串。每行一个IP地址和掩码,用~隔开。

输出描述:

统计A、B、C、D、E、错误IP地址或错误掩码、私有IP的个数,之间以空格隔开。

示例1

输入

10.70.44.68~255.254.255.0
1.0.0.1~255.0.0.0
192.168.0.2~255.255.255.0
19..0.~255.255.255.0

输出

1 0 1 0 0 2 1

解题

#!/user/bin/env python3
# -*- coding: utf-8 -*-
# __author__: wing
# 2021/2/6 18:30
import sys
A = []
B = []
C = []
D = []
E = []
err = []
private = []


def checkmask(mask):
mask_list = mask.split('.')
mask_bin_str = ''
for num_str in mask_list:
num = int(num_str)
num_bin_str = '{:08b}'.format(num)
mask_bin_str += num_bin_str
right = mask_bin_str.rfind('1')
left = mask_bin_str.find('0')
if left != -1:
if right<left:
return True
else:
err.append(mask)
return 'err'
else:
err.append(mask)
return 'err'


def checkip(ip):
ip_list = ip.split('.')
if ip_list[0] == '0' or ip_list[0] == '127':
return 'pass'
else:
if '' in ip_list:
err.append(ip)
return 'err'
else:
for ip_num in ip_list:
if int(ip_num) > 255:
err.append(ip)
return 'err'
num0=int(ip_list[0])
num1=int(ip_list[1])
if 1 <= num0 <= 126:
A.append(ip)
if num0 == 10:
private.append(ip)
return 'A'
elif 128 <= num0 <= 191:
B.append(ip)
if num0 == 172 and 16 <= num1 <= 31:
private.append(ip)
return 'B'
elif 192<= num0 <= 223:
C.append(ip)
if num0== 192 and num1 == 168:
private.append(ip)
return 'C'
elif 224<= num0 <= 239:
D.append(ip)
return 'D'
elif 240 <= num0 <= 255:
E.append(ip)
return 'E'


def defu_print(A, B, C, D, E, err, private):
print(str(len(A)) + ' ' + str(len(B)) + ' ' + str(len(C)) + ' ' + str(len(D)) + ' '
+ str(len(E)) + ' ' + str(len(err)) + ' ' + str(len(private)))

while True:

mm = sys.stdin.readline().strip()
if mm == '':
break
inpu = mm.split('~')
ip = inpu[0]
mask = inpu[1]
mask_staus = checkmask(mask)
if mask_staus == True:
ip_staus = checkip(ip)

defu_print(A, B, C, D, E, err, private)

 


云涯历险记 , 版权所有丨如未注明 , 均为原创丨本网站采用BY-NC-SA协议进行授权
转载请注明原文链接:编程测试:牛客华为机试
喜欢 (0)