您的位置:首页 > 其它

判断两个IP是否属于同一子网

2016-09-06 16:14 225 查看


题目描述

子网掩码是用来判断任意两台计算机的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地址是同一子网络。 

* 输入参数:    String Mask: 子网掩码,格式:“255.255.255.0”; 

*               String ip1: 计算机1的IP地址,格式:“192.168.0.254”;

*               String ip2: 计算机2的IP地址,格式:“192.168.0.1”;

*               

* 返回值:      0:IP1与IP2属于同一子网络;     1:IP地址或子网掩码格式非法;    2:IP1与IP2不属于同一子网络

*/ 

public int checkNetSegment(String mask, String ip1, String ip2) 

{     

    /*在这里实现功能*/

    return 0;

}

输入描述:
输入子网掩码、两个ip地址

输出描述:
得到计算结果

输入例子:
255.255.255.0
192.168.224.256
192.168.10.4


输出例子:
1


思路 :输入字符串后将其按照  '. '划分成相应部分,然后将对应部分进行判断

#include<iostream>
#include<string>
#include<vector>
using namespace std;
vector<int> hf(string s)
{
vector<int> m;
s = s + '.';
int i = 0; int j = 0;
while (i < s.size())
{
if (s[j] == '.')
{
string temp = s.substr(i,j-i);
int num = 0;
for (int i = 0; i < temp.size(); i++)
{
num =num* 10+temp[i]-'0';
}
m.push_back(num);
i=j+1;
j++;
}
else j++;
}
return m;
}
int main()
{
string ip, s1, s2;
while (getline(cin,ip))
{
getline(cin, s1);
getline(cin,s2);
vector<int> m = hf(ip);
vector<int> q1 = hf(s1);
vector<int> q2 = hf(s2);
bool p = true;
bool iss = true;
for (int i = 0; i < m.size() && p&&iss; i++)
{
if ((m[i] <= 255 && m[i] >= 0) && (q1[i] <= 255 && q1[i] >= 0) && (q2[i] <= 255 && q2[i] >= 0))
{
if ((m[i] & q1[i]) != (m[i] & q2[i]))iss = false;
}
else p = false;
add1

}
if (!p)cout<<1<< endl;
else if (iss)cout<<0<< endl;
else cout << 2 << endl;
}
return 0;
}
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: