子网掩码是用来判断任意两台计算机的IP地址是否属于同一子网络的根据。
子网掩码与IP地址结构相同,是32位二进制数,其中网络号部分全为“1”和主机号部分全为“0”。利用子网掩码可以判断两台主机是否中同一子网中。若两台主机的IP地址分别与它们的子网掩码相“与”后的结果相同,则说明这两台主机在同一子网中。
示例:
I P 地址 192.168.0.1
子网掩码 255.255.255.0
转化为二进制进行运算:
I P 地址 11010000.10101000.00000000.00000001
子网掩码 11111111.11111111.11111111.00000000
AND运算
11000000.10101000.00000000.00000000
转化为十进制后为:
192.168.0.0
I P 地址 192.168.0.254
子网掩码 255.255.255.0
转化为二进制进行运算:
I P 地址 11010000.10101000.00000000.11111110
子网掩码 11111111.11111111.11111111.00000000
AND运算
11000000.10101000.00000000.00000000
转化为十进制后为:
192.168.0.0
通过以上对两台计算机IP地址与子网掩码的AND运算后,我们可以看到它运算结果是一样的。均为192.168.0.0,所以这二台计算机可视为是同一子网络
输入两个ip地址,子网掩码。中间用空格隔开
输出1和第一个ip跟掩码相与后的操作结果; 或者输出0和第一个ip跟掩码相与后的操作结果;
输入
192.168.1.1 192.168.1.2 255.255.255.0
输出
1 192.168.1.0
#include <iostream>
#include <vector>
using namespace std;
void ip2number(string str, vector<int> &v){ // 将string中的ip地址划分为4份,并转化为int型数据
string strTemp;
for(int i = 0; i < str.length(); i++){
if(str[i]!='.'){
strTemp += str[i];
}
else{
if(strTemp.length() == 3){
v.push_back((strTemp[0]-48)*100+(strTemp[1]-48)*10+(strTemp[2]-48)*1);
strTemp = "";
}
else if(strTemp.length()==2){
v.push_back((strTemp[0]-48)*10+(strTemp[1]-48)*1);
strTemp = "";
}
else{
v.push_back((strTemp[0]-48)*1);
strTemp = "";
}
}
}
}
int main()
{
string ip1, ip2, mask;
cin >> ip1 >> ip2 >> mask;
ip1=ip1+'.'; //在输入的字符串末尾+'.',便于划分处理
ip2=ip2+'.';
mask = mask+'.';
vector<int> vIp1, vIp2, vMask;
ip2number(ip1, vIp1); //转化string 为 vector<int>
ip2number(ip2, vIp2);
ip2number(mask, vMask);
int num0 = vIp1[0]&vMask[0]; //ip1每一段分别和掩码做与操作
int num1 = vIp1[1]&vMask[1];
int num2 = vIp1[2]&vMask[2];
int num3 = vIp1[3]&vMask[3];
int um0 = vIp2[0]&vMask[0]; //ip2每一段分别和掩码做与操作
int um1 = vIp2[1]&vMask[1];
int um2 = vIp2[2]&vMask[2];
int um3 = vIp2[3]&vMask[3];
if(num0 == um0 && num1 ==um1 && num2 ==um2 && num3 == um3){
cout<<1<<" ";
}
else{
cout<<0<<" ";
}
cout<<num0<<"."<<num1<<"."<<num2<<"."<<num3; //输出第一个ip地址和子网掩码相与后的结果
return 0;
}
判断两个ip地址是否属于同一网段/华为2020春招机试(C/C++)
原文:https://www.cnblogs.com/pinher/p/12520912.html