判断两个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. ...
随机推荐
- java Iterator Fail-fast机制
Fail-fast:在迭代的过程中发现数据被改变时立即抛出异常,而不是等遍历完了再抛出异常:可以理解为快速感知. 在并发的时候,当线程A正遍历一个Collection或Map,这时另外一个线程B修改C ...
- ThinkPHP3.2 volist嵌套循环显示原理
php页面:$fatherList = $Document->where('pid=1')->select(); foreach($fatherList as $n=> ...
- Js图片切换
<!DOCTYPE html><html<head> <meta charset="UTF-8"> <title></t ...
- JQ学习(二)
jQuery 效果 jQuery hide() 和 show() 语法: $(selector).hide(speed,callback); $(selector).show(speed,callba ...
- 【原】iOS学习之在NSObject子类中获取当前屏幕显示的ViewController
我们在非视图类中想要随时展示一个view时,需要将被展示的view加到当前view的子视图,或用当前view presentViewController,或pushViewContrller,这些操作 ...
- BZOJ2002 & LCT模板(分块不会搞)
题意: 看题. 某天,Lostmonkey发明了一种超级弹力装置,为了在他的绵羊朋友面前显摆,他邀请小绵羊一起玩个游戏.游戏一开始,Lostmonkey在地上沿 着一条直线摆上n个装置,每个装置设定初 ...
- ubifs总体设计分析
1. 设计需求 flash设备区别与一般的块设备,有如下特点: 存在坏块 使用寿命较短 存储介质不稳定 读写速度慢 不支持随机访问(nand) 只能通过擦除将0改成1 最小读写单位为page ...
- ACM 取石子(七)
取石子(七) 时间限制:1000 ms | 内存限制:65535 KB 难度:1 描述 Yougth和Hrdv玩一个游戏,拿出n个石子摆成一圈,Yougth和Hrdv分别从其中取石子,谁先取完 ...
- linux 运行可执行文件version `GLIBC_2.17' not found
http://www.cnblogs.com/q191201771/p/3875316.html root@socfpga:/media/ram/nfs/dvb# ./a.out ./a.: vers ...
- MongoDB 用户配置
====[安装]====DOS下切换到文件所在盘符 例如 D:\MongoDB\bin设置数据库保存位置 mongod.exe --dbpath D:\MongoDB\Data [--auth]//用 ...