题目描述

请解析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就是一个非法的掩码)

输入描述:

多行字符串。每行一个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
参考讨论;子网掩码这块不是很熟悉,感觉没有特别好的算法,看起来都有点暴力
链接:https://www.nowcoder.com/questionTerminal/de538edd6f7e4bc3a5689723a7435682?f=discussion
来源:牛客网
20

Yac836【作者】

这个问题注意一下几点

  1. 255.255.255.255 为非法子网掩码(题目的意思,实际这个掩码,也能用)
  2. 当子网掩码错误时,不在判断ip是否有效,错误直接加一, 进行下次循环
  3. 当一个ip属于ABCDE类中的一个时候,也属于私有ip时,私有ip和他属于的分类都应该加一

解题的方法

  1. 判断子网掩码是否有效

    1. 通过判断是否为255.255.255.255 如果是的话,错误加一,继续下次循环
    2. 判断别的子网掩码是否正确。根据子网掩码二进制规律(开头为连续的1,然后为0),我们将子网掩码按位取反,然后加一,得到的新二进制位,然后我们通过判断二进制中1的个数来判断是否为合法的子网掩码。(因为合法的子网掩码,按位取反,加一后,二进制位中,只有一个1)
      int validMask(char *p) {
      int flag,i ;
      unsigned int b1 = 0, n[4];
      sscanf(p, "%u.%u.%u.%u", &n[3], &n[2], &n[1], &n[0]);
      if(n[0] == 255 &&n[1] == 255 &&n[2] == 255 &&n[3] == 255 ) {
      flag = false;
      return flag;
      }
      for(i = 0; i < 4; ++i)
      b1 += n[i] << (i * 8);
      b1 = ~b1 + 1;
      if((b1 & (b1 - 1)) == 0) {
      flag = true;
      } else
      flag = false;
      return flag;
      }
  2. 判断ip时候有效,我们可以通过网络编程中自带的函数进行判断

    #include <arpa/inet.h>
    int inet_pton(int family, const char *strptr, void *addrptr);
    返回:若成功则为1,若输入不是有效的表达格式则为0,若出错则为-1
  3. 如果ip地址有效,我们就可以判断它属于哪一类,是否是私有ip
  4. 完整代码

#include <stdio.h>
#include <arpa/inet.h>
#include <sys/socket.h>
#include <netinet/in.h>
#include <strings.h>
#include <stdlib.h>
#include <string.h>
#define true 1
#define false 0
int validMask(char *p) {
int flag,i ;
unsigned int b1 = 0, n[4];
sscanf(p, "%u.%u.%u.%u", &n[3], &n[2], &n[1], &n[0]);
if(n[0] == 255 &&n[1] == 255 &&n[2] == 255 &&n[3] == 255 ) {
flag = false;
return flag;
}
for(i = 0; i < 4; ++i)
b1 += n[i] << (i * 8);
b1 = ~b1 + 1;
if((b1 & (b1 - 1)) == 0) {
flag = true;
} else
flag = false;
return flag;
}
int main() {
char str[50];
int a =0, b = 0, c = 0, d = 0, e = 0, err = 0, pri = 0;
while(fgets(str,50,stdin)) {
char *tok = str;
char p[2][20] = {0};
int i = 0;
while ((tok = strtok(tok, "~")) != NULL) {
strcpy(p[i], tok);
tok = NULL;
i ++ ;
if(i == 2)
i = 0;
}
int flag = validMask(p[1]);
if(flag) {
struct in_addr s;
unsigned int ip1,ip2;
int valid = inet_pton(AF_INET,p[0],(void *)&s);
sscanf(p[0],"%u.%u",&ip1,&ip2);
if(valid) {
if(ip1>=1 && ip1 <=126)
a++;
else if(ip1>=128 && ip1 <=191)
b++;
else if(ip1>=192 && ip1 <=223)
c++;
else if(ip1>=224 && ip1 <=239)
d++;
else if(ip1>=240 && ip1 <=255)
e++;
if(ip1==10
|| (ip1==172 && ip2 >=16 &&ip2 <=31)
|| (ip1==192 && ip2 ==168))
pri ++;
} else
err ++;
} else
err++;
}
printf("%d %d %d %d %d %d %d\n",a,b,c,d,e,err,pri);
return 0;
} C里面net去解,想法很不错,不熟悉仅做参考学习。

算法 识别有效ip地址和掩码并做统计的更多相关文章

  1. 26:IPMaskCheck识别有效的ip地址和掩码并分类统计

    题目描述 请解析IP地址和对应的掩码,进行分类识别.要求按照A/B/C/D/E类地址归类,不合法的地址和掩码单独归类. 所有的IP地址划分为 A,B,C,D,E五类 A类地址1.0.0.0~126.2 ...

  2. Python 输入IP地址及掩码告诉你该网段包含的全部地址(IPy模块练习)

    IPy模块原本使用时需要输入正确的网络位和掩码,我利用处理报错的机制实现了输入任意IP地址和掩码均可正确输出结果的小程序. #!/usr/bin/env python # -*- coding: ut ...

  3. 根据Ip地址与掩码 得出 子网地址与广播地址

    由于给予条件优先,没有直接给出子网地址与广播地址.但是又需要这两个参数,需要我们使用ip 地址与 子网掩码得出子网地址与广播地址.思路如下:       1. 子网地址, ip地址与 子网掩码分别换算 ...

  4. 设置ip地址、掩码、网关、DNS

    @echo offcolor f8mode con cols=40 lines=8echo.echo.echo      设置IP为:echo.set /p ip=              192. ...

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

    该题我的想法是把每一个ip看出一个整数,将读取得到的数据一一与给定的ip范围比较即可.另外本题应该注意的地方是scanf读取俩字符串的方法. 代码如下: #include<stdio.h> ...

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

    #include<iostream> #include<stdio.h> #include<string.h> using namespace std; int c ...

  7. IP地址分类与识别错误

    //描述:  请解析IP地址和对应的掩码,进行分类识别.要求按照A/B/C/D/E类地址归类,不合法的地址和掩码单独归类. //所有的IP地址划分为 A,B,C,D,E五类 //A类地址1.0.0.0 ...

  8. 【Linux网络基础】网络子网划分基础知识(IP地址,子网)

    一. IP地址分类与子网划分基础 1. 什么是IP地址? 常见的ip地址版本为ipv4, ipv6 32位 4 * 8=32位. 32位二进制数字序列组成的数字序列   点分十进制 采用点将32位数字 ...

  9. IP地址、子网掩码详解

    如何通过子网掩码划分网段 资料一: 一.缺省A.B.C类地址,子网掩码:  二.子网掩码的作用:  code:  IP地址 192.20.15.5 11000000 00010100 00001111 ...

随机推荐

  1. Java后端进阶教程

    https://www.cnblogs.com/caoleiCoding/p/6170555.html 传智播客Java Spring框架:https://www.bilibili.com/video ...

  2. jpa remove

    直接使用em.remove会报错,IllegalArgumentException: Removing a detached instance 即对象处于脱管的状态,使用merge使之被session ...

  3. 术语-PM:PM/项目管理 百科

    ylbtech-术语-PM:PM/项目管理 百科 PM项目管理(Project Management),是以项目为对象的系统管理方法,通过一个临时性的.专门的柔性组织,对项目进行高效率的计划.组织.指 ...

  4. vs2017或vs2019添加引用时报错

    我先安装的是vs2019,进入VS命令提示符里后一直说:gacutil 不是有效的命令,一直没能解决,然后直接装了vs2017后,该命令可以使用了, 还是用VS2017吧,2019的版本感觉还有点问题 ...

  5. RESTful_基础知识

    目录 目录 前言 RESTful REST原则 REST的Web原则 分层系统原则 RESTful的实现 SOA 面向服务的体系结构 RPC样式 Web服务 RPC的实现过程 SOAP 简单对象访问协 ...

  6. pandas 增删改查

    原文链接:https://blog.csdn.net/zhangchuang601/article/details/79583551 准备工作:增.删.改.查的方法有很多很多种,这里只展示出常用的几种 ...

  7. PHP 数组下标自动转换为整型的坑

    在做项目时,上线后遇到一个 BUG,有一个数组存储了下标从 '01'到'18' 总共18组数据.上线前测试了前几组数据,没问题.上线后,在用户选择'15'时报错,找不到这个数据.查了一下代码,数据是没 ...

  8. Vagrant 入门 - 网络

    原文地址 现在,我们启动了 web 服务器,并且通过同步目录使用宿主机上的文件提供服务.然而,还只能通过虚拟机中的终端访问服务器.这一章节中,我们会使用 Vagrant 的网络特性,配置 Vagran ...

  9. 网络流强化-HDU2732

    第一次遇到加了“多余”的边会导致WA的——在我看来是很多余,见代码191行 之后会思考为什么,想出来再更. 问题弄明白了,如果你在连接边连了一条到没有柱子的点的边,这个没有柱子的点是不可能连到终点的, ...

  10. 转 Python selenium 强制等待显示等待隐式等待

    1. 1. 强制等待第一种也是最简单粗暴的一种办法就是强制等待sleep(xx),强制让闪电侠等xx时间,不管凹凸曼能不能跟上速度,还是已经提前到了,都必须等xx时间. 看代码: # -*- codi ...