判断两个IP是否属于同一子网
描述 |
子网掩码是用来判断任意两台计算机的IP地址是否属于同一子网络的根据。 示例: 转化为二进制进行运算: I P 地址 11010000.10101000.00000000.00000001 AND运算 转化为十进制后为: I P 地址 192.168.0.254 转化为二进制进行运算: I P 地址 11010000.10101000.00000000.11111110 AND运算 转化为十进制后为: 通过以上对两台计算机IP地址与子网掩码的AND运算后,我们可以看到它运算结果是一样的。均为192.168.0.0,所以这二台计算机可视为是同一子网络。 /* * 返回值: 0:IP1与IP2属于同一子网络; 1:IP地址或子网掩码格式非法; 2:IP1与IP2不属于同一子网络 |
---|---|
知识点 | 字符串 |
运行时间限制 | 10M |
内存限制 | 128 |
输入 |
输入子网掩码、两个ip地址 |
输出 |
得到计算结果 |
样例输入 | 255.255.255.0 192.168.224.256 192.168.10.4 |
样例输出 | 1 |
package com.oj; import java.util.Scanner; public class TestOj {
public static void main(String[] args) {
Scanner in = new Scanner(System.in);
//String input = in.nextLine();
String[] data = new String[3];
data[0] = in.nextLine();
data[1] = in.nextLine();
data[2] = in.nextLine();
if(data.length!=3){
System.out.println("1");
return ;
}
String[] masks = data[0].split("\\.");
String[] ips = data[1].split("\\.");
String[] ips2 = data[2].split("\\."); if(masks.length!=4||ips.length!=4||ips2.length!=4){
System.out.println("1");
return ;
} int[] mask = new int[4];
int[] ip = new int[4];
int[] ip2 = new int[4];
for(int i = 0;i < 4; i++){
try{
mask[i] = Integer.parseInt(masks[i]);
ip[i] = Integer.parseInt(ips[i]);
ip2[i] = Integer.parseInt(ips2[i]);
if(mask[i]<0&&mask[i]>255){
System.out.println("1");
return;
} if(ip[i]<0&&ip[i]>255){
System.out.println("1");
return;
} if(ip2[i]>0&&ip2[i]>255){
System.out.println("1");
return;
}
}catch(Exception e){
System.out.println("1");
return;
}
} StringBuilder masksb = new StringBuilder();
StringBuilder ipsb = new StringBuilder();
StringBuilder ipsb2 = new StringBuilder();
for(int i = 0;i < 4; i++){
String temp = Integer.toBinaryString(mask[i]);
if(temp.length()!=8)
for(int j = 0;j < 8-temp.length(); j++)
masksb.append("0");
masksb.append(temp); String temp2 = Integer.toBinaryString(ip[i]);
if(temp2.length()!=8)
for(int j = 0;j < 8-temp2.length(); j++)
ipsb.append("0");
ipsb.append(temp2);
//System.out.println("ipsb: "+ipsb.toString()); String temp3 = Integer.toBinaryString(ip2[i]);
if(temp3.length()!=8)
for(int j = 0;j < 8-temp3.length(); j++)
ipsb2.append("0");
ipsb2.append(temp3);
}
StringBuilder a = new StringBuilder();
for(int i = 0;i < masksb.toString().length(); i++)
if(masksb.charAt(i)=='1'&&ipsb.charAt(i)=='1')
a.append("1");
else
a.append("0"); StringBuilder b = new StringBuilder();
for(int i = 0;i < masksb.toString().length(); i++)
if(masksb.charAt(i)=='1'&&ipsb2.charAt(i)=='1')
b.append("1");
else
b.append("0"); if(a.toString().equals(b.toString()))
System.out.println("0");
else
System.out.println("2");
}
}
判断两个IP是否属于同一子网的更多相关文章
- 判断两个IP是否处于同一子网(网段)
如何去判断A和B两个IP是否在同一网段,假如有如下两个IP地址和子网掩码,判断他们是否是同一个网段的IP地址的方法: A IP:202.194.128.9 B IP:202.194.128.14 子网 ...
- 判断两个IP地址是不是属于同一子网的方法
一个IP地址有三种写法: 第一种,单个IP,如192.168.55.28 第二种,IP/子网掩码,如192.168.55.28/255.255.255.0 第三种,IP/子网掩码长度,如192.168 ...
- python 判断两个ip地址是否属于同一子网
python 判断两个ip地址是否属于同一子网 """ 判断两个IP是否属于同一子网, 需要判断网络地址是否相同 网络地址:IP地址的二进制与子网掩码的二进制地址逻辑&q ...
- [置顶] 如何判断两个IP大小关系及是否在同一个网段中
功能点 判断某个IP地址是否合法 判断两个IP地址是否在同一个网段中 判断两个IP地址的大小关系 知识准备 IP协议 子网掩码 Java 正则表达式 基本原理 IP地址范围 0.0.0.0- 255 ...
- 如何判断两个IP地址是不是在同一个网段
要判断两个IP地址是不是在同一个网段,就将它们的IP地址分别与子网掩码做与运算,得到的结果一网络号,如果网络号相同,就在同一子网,否则,不在同一子网. 例:假定选择了子网掩码255.255.254. ...
- 如何判断两个IP是否在同一网段
下来举例说明,如何去判断A和B两个IP是否在同一网段. A IP:202.194.128.9 B IP:202.194.128.14 子网掩码:255.255.255.0 1.把A和B的地址转换为二进 ...
- 如何判断两个IP地址是不是处于同一网段?
个人理解,欢迎指正. 一.要判断两个IP地址是不是在同一个网段,就将它们的IP地址分别与子网掩码做与运算,得到的结果-->网络号,如果网络号相同, 就在同一子网,否则,不在同一子网. 例:假定选 ...
- python 判断两个ip是不是处于同一网段
a_ip:10.10.15.100b_ip:10.10.15.101c_ip:10.10.10.100netmask:255.255.255.0 def numtobinary(num): binar ...
- [转,讲的非常精彩]CIDR地址块及其子网划分(内含原始IP地址分类及其子网划分的介绍)
http://blog.csdn.net/dan15188387481/article/details/49873923 CIDR地址块及其子网划分(内含原始IP地址分类及其子网划分的介绍) 1. ...
随机推荐
- 【spring set注入 注入集合】 使用set注入的方式注入List集合和Map集合/将一个bean注入另一个Bean
Dao层代码: package com.it.dao; public interface SayHell { public void sayHello(); } Dao的Impl实现层: packag ...
- JMeter性能监测插件介绍(三)
JMeter 性能监测插件介绍 压力测试过程中,能够随时对负载服务器的健康状况的把控是相当重要的,有了这些数据,我们才能准确分析出服务器负载瓶颈.JMeter 插件包现在能够支持服务器监控,可以在所有 ...
- Asp.Net Mvc 控制器与视图的数据传递
数据传递也就是控制器和视图之间的交互,比如在视图中提交的数据,在控制器怎么获取,或者控制器从业务层获得一些数据,怎么传递到视图中,让视图显示在客户端呢?带着这些疑问,我们接着看.. 下面 ...
- Python version 2.7 required, which was not found in the registry
http://blog.csdn.net/zdnlp/article/details/12171687
- The 2015 China Collegiate Programming Contest C. The Battle of Chibi hdu 5542
The Battle of Chibi Time Limit: 6000/4000 MS (Java/Others) Memory Limit: 65535/65535 K (Java/Othe ...
- 【Oracle】Oracle 11g 64位安装完后,ora-12541错误和ora-12514错误的解决
问题描述: 干净的windows2008 64位服务器上安装 oracle 11g R2 64bit服务端,安装完后,NetManager中默认的主机名为localhost,可以测试通过.但是无法在别 ...
- BZOJ3092 : [FDU2012校赛] A Famous King’s Trip
题目等价于去掉两条边,使得剩下的图连通,且所有点度数都为偶数. 首先特判掉图一开始就不连通的情况. 求出dfs生成树,对于每条非树边随机一个权值,每条树边的权值为所有经过它的非树边权值的异或和. 那么 ...
- 限制Boltzmann机(Restricted Boltzmann Machine)
起源:Boltzmann神经网络 Boltzmann神经网络的结构是由Hopfield递归神经网络改良过来的,Hopfield中引入了统计物理学的能量函数的概念. 即,cost函数由统计物理学的能量函 ...
- Topcoder SRM 626 DIV2 SumOfPower
本题就是求所有连续子数列的和 开始拿到题目还以为求的时数列子集的和,认真看到题目才知道是连续子数列 循环遍历即可 int findSum(vector <int> array) { ; ; ...
- xenu工具介绍
Xenu Link Sleuth 也许是你所见过的最小但功能最强大的检查网站死链接的软件了.你可以打开一个本地网页文件来检查它的链接,也可以输入任何网址来检查.它可以分别列出网站 的活链接以及死链接, ...