识别有效的IP地址和掩码并进行分类统计
来源:互联网 发布:数据库分组多条件查询 编辑:程序博客网 时间:2024/05/19 23:16
#include <iostream>#include <string>#include <vector>#include <stdlib.h>using namespace std;static int result[7]={0}; //保存最后结果的数组string Chang(string str) //转换为二进制{int num=atoi(str.c_str());string tmp;char tmp1[10]={0};itoa(num,tmp1,2); //把num转换为二进制,并以字符串形式保存tmp=string(tmp1);if (tmp.size()<8) //如果不够8位,就在前面补0,使其够8位{string tmp2(8-tmp.size(),'0');str=tmp2+tmp;}elsestr=tmp;return str;}void checkNetSegment(string mask,string ip1){int count1=0,count2=0;int count4=0,count5=0;string str1[4],str3[4];for(int i=0; i<mask.size(); i++) //掩码的点个数(不连续的点等于3个)if(mask[i]=='.' && mask[i+1]!='.')count1++;for(int i=0; i<ip1.size(); i++) //ip1的点个数if(ip1[i]=='.' && ip1[i+1]!='.')count2++;for(int i=0; i<mask.size(); i++) //掩码的点个数(所有的点等于3个)if(mask[i]=='.')count4++;for(int i=0; i<ip1.size(); i++) //ip1的点个数if(ip1[i]=='.')count5++;if(count1==count2&&count1==3&& count4==count5&&count4==3) //如果格式正确{int i=0; //ip1先分解为4段int flag1=0;int k=0;while(i<ip1.size()){int tmp=i;while(isdigit(ip1[tmp]))tmp++;str1[k]=ip1.substr(i,tmp-i);k++;i=tmp+1;}i=0; //掩码分为4段int flag3=0,flagmk=0;k=0;string test;while(i<mask.size()){int tmp=i;while(isdigit(mask[tmp]))tmp++;str3[k]=mask.substr(i,tmp-i);k++;i=tmp+1;}for(int i=0; i<4; i++) //判断每一段的值是否在0-255之间if(atoi(str1[i].c_str())<256 &&atoi(str1[i].c_str())>=0)flag1++;for(int i=0; i<4; i++)if(atoi(str3[i].c_str())<256 &&atoi(str3[i].c_str())>=0)flag3++;for (int i=0;i<4;i++) //判掩码是不是1在0前面{string temp=Chang(str3[i]);test+=temp;}for (int j=1;j<32-1;j++)if (test[j-1]>test[j] && test[j]<test[j+1]){flagmk=1;break;}if(flag1==flag3 &&flag3==4 &&flagmk==0) //格式正确{if (str1[0]>="1" &&str1[0]<="126" )result[0]++;else if (str1[0]>="128" &&str1[0]<="191")result[1]++;else if (str1[0]>="192"&&str1[0]<="223")result[2]++;else if (str1[0]>="224"&&str1[0]<="239")result[3]++;else if (str1[0]>="240"&&str1[0]<="255")result[4]++;else if (str1[0]=="127")result[5]++;if (str1[0]=="10"|| //私有IP(str1[0]=="172"&&str1[1]>="16"&&str1[1]<="31")||(str1[0]=="192"&&str1[1]=="168"))result[6]++;}elseresult[5]++;}else //格式不正确result[5]++;}int main(){string s1,ms,ip;while (getline(cin,s1)){int position=s1.find("~",0);ip=s1.substr(0,position);ms=s1.substr(position+1,s1.size()-1);checkNetSegment(ms,ip);}for (int i=0;i<7;i++){cout<<result[i];if (i==6)cout<<endl;elsecout<<" ";}return 0;}
0 0
- 识别有效的IP地址和掩码并进行分类
- 识别有效的IP地址和掩码并进行分类统计
- [华为机试练习题]34.识别有效的IP地址和掩码并进行分类统计
- 识别有效的IP地址和掩码并进行分类统计
- 华为OJ(识别有效的IP地址和掩码并进行分类统计)
- 识别有效的IP地址和掩码并进行分类统计
- 华为OJ中级题-识别有效的IP地址和掩码并进行分类统计
- 华为机试——识别有效的IP地址和掩码并进行分类统计
- 华为机试——识别有效的IP地址和掩码并进行分类统计
- 识别有效的IP地址和掩码并进行分类统计
- 【华为OJ】【018-识别有效的IP地址和掩码并进行分类统计】
- 识别有效的IP地址和掩码并进行分类统计
- 识别有效的IP地址和掩码并进行分类统计 java
- 华为oj 识别有效的IP地址和掩码并进行分类统计
- OJ中----识别有效的IP地址和掩码并进行分类统计
- 识别有效的IP地址和掩码并进行分类统计
- 华为机试题——识别有效的IP地址和掩码并进行分类统计
- Java-NowCoder-识别有效的IP地址和掩码并进行分类统计
- 笑傲测试!!!
- 南邮 OJ 1967 蜜蜂蜂房路线问题
- Language Guide (proto3)
- Item里的Button不可点击
- POJ 1155 TELE(树形DP)
- 识别有效的IP地址和掩码并进行分类统计
- hihocoder 1074 字体设计(RMQ问题,ST算法)
- Linux之文件操作(2)
- COM 导出结构体,DLL 导出结构体
- mac 安装SourceInsight
- 指针数组与const指针,以及warning:deprecated conversion from string constant to 'char *'
- 通过服务器向指定客户端发送消息
- CodeForces 3A - Shortest path of the king
- 内存映像文件简介