//描述:  请解析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

//输入:  

//多行字符串。每行一个IP地址和掩码,已~隔开。如:

//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 

//输出:  

//统计A、B、C、D、E、错误IP地址或错误掩码、私有IP的个数,之间以空格隔开,根据上面的IP,可以得到:

//1.0.0.1~255.0.0.0 ----A类

//192.168.0.2~255.255.255.0  ----C类,私有

//10.70.44.68~255.254.255.0----错误的掩码

//19..0.~255.255.255.0-----错误的IP

//可以得到统计数据如下:

//1 0 1 0 0 2 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

#include <stdio.h>
#include <stdlib.h>
#include <string.h> int main(void){
int A=0,B=0,C=0,D=0,E=0,err_ip_mask=0,private_ip=0;
int ip[4], netmask[4], myip[8];
int input_len, k, flag, one, one1;
unsigned int temp, temp1;
char input[100]; while(gets(input)){
flag = 0;
memset(ip, -1, sizeof(int)*4);
memset(netmask, -1, sizeof(int)*4);
if(sscanf(input, "%d.%d.%d.%d~%d.%d.%d.%d", &ip[3], &ip[2], &ip[1], &ip[0], &netmask[3], &netmask[2], &netmask[1], &netmask[0])==-1){
//err_ip_mask++;
break;
}
else{
for(k=0; k<4; k++){
if(ip[k]>=0&&ip[k]<=255)
continue;
else{
err_ip_mask++;
flag = 1;
break;
}
}
if(flag) continue;
for(k=0; k<4; k++){
if(netmask[k]>=0&&netmask[k]<=255)
continue;
else{
err_ip_mask++;
flag = 1;
break;
}
}
if(flag) continue;
temp = netmask[0]+(netmask[1]<<8)+(netmask[2]<<16)+(netmask[3]<<24);
one = 0; temp1 = temp;
while(temp1){
one++;
temp1 = temp1&(temp1-1);
}
one1 = 0; temp1 = temp>>(32-one);
while(temp1){
one1++;
temp1 = temp1&(temp1-1);
}
if(one1!=one){
err_ip_mask++;
continue;
}
if(ip[3]>=1&&ip[3]<=126) A++;
if(ip[3]>=128&&ip[3]<=191) B++;
if(ip[3]>=192&&ip[3]<=223) C++;
if(ip[3]>=224&&ip[3]<=239) D++;
if(ip[3]>=240) E++;
if(ip[3]==10) private_ip++;
if(ip[3]==172&&ip[2]>=16&&ip[2]<=31) private_ip++;
if(ip[3]==192&&ip[2]==168) private_ip++;
}
} printf("%d %d %d %d %d %d %d", A,B,C,D,E,err_ip_mask,private_ip);
system("pause");
return 0;
}

IP地址分类与识别错误的更多相关文章

  1. [转,讲的非常精彩]CIDR地址块及其子网划分(内含原始IP地址分类及其子网划分的介绍)

    http://blog.csdn.net/dan15188387481/article/details/49873923 CIDR地址块及其子网划分(内含原始IP地址分类及其子网划分的介绍)   1. ...

  2. IP地址分类(转)

    IP地址分类以及C类IP地址的子网划分 国际规定:把所有的IP地址划分为 A,B,C,D,E A类地址:范围从0-127,0是保留的并且表示所有IP地址,而127也是保留的地址,并且是用于测试环回用的 ...

  3. 3.IP地址分类_规划_子网掩码

    IP地址分类_规划_子网掩码 3.1MAC地址 网卡的身份证号———MAC地址 MAC地址的长度为48位(6个字节),通常表示为12个16进制数,每2个16进制数之间用冒号隔开,如:08:00:20: ...

  4. IP地址分类及私网IP

    5类IP地址: IP地址共有32位字节,其中A~C类IP地址由类标识号.网络地址和主机地址组成,A类标识最高位为0,网络地址为1字节,主机地址为3字节, B类标识最高位为10,网络地址为2字节,主机地 ...

  5. ip地址分类和网段区分

    IP地址分类/IP地址10开头和172开头和192开头的区别/判断是否同一网段 简单来说在公司或企业内部看到的就基本都是内网IP,ABC三类IP地址里的常见IP段. 每个IP地址都包含两部分,即网络号 ...

  6. IP地址分类百科

    IP地址分类介绍 这里讨论IPv4,IP地址分成了A类.B类.C类.C类.E类,如下图所示: 解释: A类以0开头,网络地址有7位,主机地址有24位,举例:A类地址:0 10000000 000000 ...

  7. IP地址分类(A类 B类 C类 D类 E类)

    IP地址分类(A类 B类 C类 D类 E类) IP地址由四段组成,每个字段是一个字节,8位,最大值是255,, IP地址由两部分组成,即网络地址和主机地址.网络地址表示其属于互联网的哪一个网络,主机地 ...

  8. IP地址分类和网段区分的知识

    IP地址分类/IP地址10开头和172开头和192开头的区别/判断是否同一网段 简单来说在公司或企业内部看到的就基本都是内网IP,ABC三类IP地址里的常见IP段. 每个IP地址都包含两部分,即网络号 ...

  9. 计算机网络【3】—— IP地址分类与子网划分

    一.IP地址分类

随机推荐

  1. Socket也有专门的Unicode版本

    https://www.chilkatsoft.com/refdoc/wcppCkSocketWRef.html https://www.chilkatsoft.com/refdoc/vcCkSock ...

  2. C# System.Uri类_获取Url的各种属性_文件名_参数_域名_端口等等

    System.Uri类用于处理Uri地址信息,常用到它的地方有,相对Uri地址转绝对Uri地址,获取Uri的某部分信息等等,可以说是一个非常有用的类. 一.属性 AbsolutePath 获取 URI ...

  3. bzoj1654 [Usaco2006 Jan]The Cow Prom 奶牛舞会

    Description The N (2 <= N <= 10,000) cows are so excited: it's prom night! They are dressed in ...

  4. sizeof与类,继承,virtual的种种(整理)

    对虚继承层次的对象的内存布局,在不同编译器实现有所区别. 首先,说说GCC的编译器. 它实现比较简单,不管是否虚继承,GCC都是将虚表指针在整个继承关系中共享的,不共享的是指向虚基类的指针. clas ...

  5. 关于Winsock编程中IO重叠的概念

    我在看<Windows网络与通信程序设计>(王艳平)这本书时,对重叠IO很不理解,突然就冒出这么一个概念,没一点头绪.就目前的理解做一个整理. 第一种理解:OVERLAPPED,顾名思义为 ...

  6. postgresql基本语句

    preface,熟悉pgsql sql Language article disorder; 1,pgsql数据库控制台Cli(command line interface) help mannual ...

  7. 【Python】Coding the Matrix:Week 5: Dimension Homework 5

    这一周的作业,刚压线写完.Problem3 没有写,不想证明了.从Problem 9 开始一直到最后难度都挺大的,我是在论坛上看过了别人的讨论才写出来的,挣扎了很久. Problem 9在给定的基上分 ...

  8. IOS7 UITableView一行滑动删除后 被删除行的下一行的点击事件将被忽略解决办法

    - (UITableViewCellEditingStyle)tableView:(UITableView *)tableView editingStyleForRowAtIndexPath:(NSI ...

  9. 449A - Jzzhu and Chocolate 贪心

    一道贪心题,尽量横着切或竖着切,实在不行在交叉切 #include<iostream> #include<stdio.h> using namespace std; int m ...

  10. uva 714 - Copying Books(贪心 最大值最小化 二分)

    题目描写叙述开头一大堆屁话,我还细致看了半天..事实上就最后2句管用.意思就是给出n本书然后要分成k份,每份总页数的最大值要最小.问你分配方案,假设最小值同样情况下有多种分配方案,输出前面份数小的,就 ...