IP地址分类与识别错误
//描述: 请解析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地址分类与识别错误的更多相关文章
- [转,讲的非常精彩]CIDR地址块及其子网划分(内含原始IP地址分类及其子网划分的介绍)
http://blog.csdn.net/dan15188387481/article/details/49873923 CIDR地址块及其子网划分(内含原始IP地址分类及其子网划分的介绍) 1. ...
- IP地址分类(转)
IP地址分类以及C类IP地址的子网划分 国际规定:把所有的IP地址划分为 A,B,C,D,E A类地址:范围从0-127,0是保留的并且表示所有IP地址,而127也是保留的地址,并且是用于测试环回用的 ...
- 3.IP地址分类_规划_子网掩码
IP地址分类_规划_子网掩码 3.1MAC地址 网卡的身份证号———MAC地址 MAC地址的长度为48位(6个字节),通常表示为12个16进制数,每2个16进制数之间用冒号隔开,如:08:00:20: ...
- IP地址分类及私网IP
5类IP地址: IP地址共有32位字节,其中A~C类IP地址由类标识号.网络地址和主机地址组成,A类标识最高位为0,网络地址为1字节,主机地址为3字节, B类标识最高位为10,网络地址为2字节,主机地 ...
- ip地址分类和网段区分
IP地址分类/IP地址10开头和172开头和192开头的区别/判断是否同一网段 简单来说在公司或企业内部看到的就基本都是内网IP,ABC三类IP地址里的常见IP段. 每个IP地址都包含两部分,即网络号 ...
- IP地址分类百科
IP地址分类介绍 这里讨论IPv4,IP地址分成了A类.B类.C类.C类.E类,如下图所示: 解释: A类以0开头,网络地址有7位,主机地址有24位,举例:A类地址:0 10000000 000000 ...
- IP地址分类(A类 B类 C类 D类 E类)
IP地址分类(A类 B类 C类 D类 E类) IP地址由四段组成,每个字段是一个字节,8位,最大值是255,, IP地址由两部分组成,即网络地址和主机地址.网络地址表示其属于互联网的哪一个网络,主机地 ...
- IP地址分类和网段区分的知识
IP地址分类/IP地址10开头和172开头和192开头的区别/判断是否同一网段 简单来说在公司或企业内部看到的就基本都是内网IP,ABC三类IP地址里的常见IP段. 每个IP地址都包含两部分,即网络号 ...
- 计算机网络【3】—— IP地址分类与子网划分
一.IP地址分类
随机推荐
- Planner – 项目管理软件
http://www.appinn.com/planner/ Planner 是一款开源.易用.跨平台的项目管理软件.@appinn 二猪用了 OpenProject 几年,现在已经受够了它的各种 ...
- 配置文件入门 - WebConfig.config常用配置节点介绍
一.配置文件入门 .Net提供了一种保存项目配置信息的办法,就是利用配置文件,配置文件的后缀一般是.config.在WinForm程序中配置文件一般是App.config.在Asp.net中一般默认是 ...
- SVD学习
前言: 上一次写了关于PCA与LDA的文章,PCA的实现一般有两种,一种是用特征值分解去实现的,一种是用奇异值分解去实现的.在上篇文章中便是基于特征值分解的一种解释.特征值和奇异值在大部分人的印象中, ...
- Android Studio 调试过程中快捷查看断点处变量值(Ctrl+Shift+I无效)?
当你在做Keymap到Eclipse后,在debug过程中,在Eclipse中我们很喜欢用Ctrl+Shift+I去查看一个运算或者调用的结果,这样用起来很方便.但是keymap到Eclipse后,你 ...
- Luci流程分析(openwrt下)
1. 页面请求: 1.1. 代码结构 在openwrt文件系统中,lua语言的代码不要编译,类似一种脚本语言被执行,还有一些uhttpd服务器的主目录,它们是: /www/index.html cgi ...
- windows phone中,将crash report记录下来,写入文件,方便分析
APP出现crash(崩溃)总是不能忍的 当我们连接调试器调试的时候,发现每当APP崩溃的时候 程序都会走到App.xaml.cs中的 // Code to execute on Unhandled ...
- LeeCode-Roman to Integer
Given a roman numeral, convert it to an integer. Input is guaranteed to be within the range from 1 t ...
- ZOJ-3410Layton's Escape(优先队列+贪心)
Layton's Escape Time Limit: 2 Seconds Memory Limit: 65536 KB Professor Layton is a renowned arc ...
- REDHAT、CenterOS使用安装Linux系统时的光盘镜像来安装软件
使用安装Linux系统时的光盘镜像来安装软件 (1)以虚拟机上,安装mysql为例: 查看mysql是否安装 rpm -qa|grep -i mysql 显示下面,证明mysql已安装客户端,下 ...
- textContent、innerText 以及Event事件兼容性问题
今天在完成前端的简单练习时发现了一些兼容性的问题,百度后得以解决. 这里主要讨论Firefox与Chrome的兼容性问题. textContent与 innerText 在javascript中, 为 ...