判断两个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
@echo offset filename=%date:~0,4%%date:~5,2%%date:~8,2%%time:~0,2%%time:~3,2%%time:~6,2%mysqldump -- ...
- html php 重定向 跳转 刷新
1秒后跳转 法一: <!DOCTYPE HTML> <html> <head> <meta http-equiv="refresh" ...
- [xsd学习]xsd基本要素
一.xsd常用数据格式 xs:string xs:decimal xs:integer xs:boolean xs:date xs:time 二.简易元素 <xs:element name=&q ...
- PHP 配置文件详解(php.ini 详解 )
[PHP] ; PHP还是一个不断发展的工具,其功能还在不断地删减 ; 而php.ini的设置更改可以反映出相当的变化, ; 在使用新的PHP版本前,研究一下php.ini会有好处的 ;;;;;;;; ...
- 【noip2014T3】
上文有提到noip2014还有没A的嘛..就先把这个坑给填了 flappy bird好sad啊 还是先做解方程 八中的数据好强了,然而我最后凑了四个质数就A了,感谢shy! 作为联赛最后一题,学习它的 ...
- iOS KVC valueForKeyPath学习心得
#import <Foundation/Foundation.h> @interface myClass1 : NSObject @property (nonatomic, copy) N ...
- ural 2070. Interesting Numbers
2070. Interesting Numbers Time limit: 2.0 secondMemory limit: 64 MB Nikolay and Asya investigate int ...
- jquery.cookie.js使用
1.下载jquery.cookie.js 官网:http://plugins.jquery.com/cookie/ 或 http://pan.baidu.com/s/1mgynA8g 2.使用方法 $ ...
- 【BZOJ】2924: [Poi1998]Flat broken lines
题意 平面上有\(n\)个点,如果两个点的线段与\(x\)轴的角在\([-45^{\circ}, 45^{\circ}]\),则两个点可以连线.求最少的折线(折线由线段首尾相连)使得覆盖所有点. 分析 ...
- CF 9D. How many trees?(dp)
题目链接 以前做过类似的,USACO,2.3,开始数组开小了,导致数据乱了,然后超数据范围了,.. #include <cstdio> #include <iostream> ...