判断两个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. ...
随机推荐
- mysql注入研究
网址: http://www.jb51.net/article/14446.htm http://www.jb51.net/article/29445.htm
- LoadRunner中循环操作
Action() { //Loadrunner中的FOR,WHILE,DO 循环语句 int i; int whileloop = 1; //FOR 循环 for (i=1;i&l ...
- 多个$(document).ready()函数的执行顺序问题,(未解决)
今天遇到了一个问题: jQuery获取不了动态添加的元素,我使用的是append添加的.寻求了帮助,得到解决方案: 在文件开头写上这样一段代码来获取,写在$(document).ready()里面. ...
- SpringMVC解析1-使用示例
Spring MVC分离了控制器.模型对象.分派器以及处理程序对象的角色,这种分离让它们更容易进行定制.Spring的MVC是基于servlet功能实现的,通过实现Servlet接口的Dispatch ...
- AC自动机+全概率+记忆化DP UVA 11468 Substring
题目传送门 题意:训练指南P217 分析:没有模板串也就是在自动机上走L步,不走到val[u] == v的节点的概率 PS:边读边insert WA了,有毒啊! #include <bits/s ...
- HDU5863 cjj's string game(DP + 矩阵快速幂)
题目 Source http://acm.split.hdu.edu.cn/showproblem.php?pid=5863 Description cjj has k kinds of charac ...
- Poj1852
题目求的是:所有蚂蚁用最短时间从木棍上走下来的最大值(也就是最后一个蚂蚁什么时候走下来的) 所有蚂蚁中,用时最长的情况 PS:根本不用考虑两只蚂蚁相遇又折返的情况(可以直接认为是他两互不影响的走) # ...
- BZOJ4635 : 数论小测验
第一问: 设$a[i]$表示使用$[1,i]$的数字$n$次形成的数组里有多少个$\gcd=1$. 考虑容斥,则$a[i]=i^n-\sum_{j=2}^i a[\lfloor\frac{i}{j}\ ...
- gulp + webpack 构建多页面前端项目
修改增加了demo地址 gulp-webpack-demo 之前在使用gulp和webpack对项目进行构建的时候遇到了一些问题,最终算是搭建了一套比较完整的解决方案,接下来这篇文章以一个实际项目为例 ...
- 最短路径dijkstra算法
畅通工程续 Time Limit: 3000/1000 MS (Java/Others) Memory Limit: 32768/32768 K (Java/Others)Total Submi ...