判断两个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. ...
随机推荐
- redis 的使用 ( list列表类型操作)
list 数据类型 列表类型 list 类型是一个双向操作 从链表的头部或者尾部添加删除元素 list 既可以用作栈 也可以用作队列 list 链表的类型应用场合: 获取最新的 10 个用户的信息 s ...
- BestCoder Round #72 (div.2)
后面的题目补不懂了 暴力 1001 Clarke and chemistry 这题也把我搞死了..枚举系数判断就行了 #include <cstdio> #include <algo ...
- Codeforces Round #338 (Div. 2)
水 A- Bulbs #include <bits/stdc++.h> using namespace std; typedef long long ll; const int N = 1 ...
- git 学习笔记7--branch
分支是git的必杀技. 站点另一个角度,分支是的快照移动有向图,刚好是拓扑排序的一种例子. basic git branch testing #创建分支 git checkout testing #切 ...
- HTML5学习之路
出于公司项目需求,我现在开始学习html5,虽然零零散散有过一点,比如说新出的语义化标签,本地存储之类的,但是从来都没有系统的去了解.
- js 对象(Object)
一.对象 除了字符串.数字.true.false.null和undefined之外,javascript中的值都是对象. javascript对象属性包括名字和值,属性名可以是包含空字符串在内的任意字 ...
- Singleton模式——对象创建型模式
Singleton模式即为单例模式/单件模式. (一)意图--保证一个类仅有一个实例,并提供一个访问它的全局访问点. 如一台计算机可以有多个端口,但是应该统一管理这些端口,避免访问冲突.--选择Sin ...
- c#如何使用正则表达式ZZ
什么是正则表达式 正则表达式是用来检验和操作字符串的强大工具.简单的理解正则表达式可以认为是一种特殊的验证字符串.正则表达式常见运用是验证用户输入信息格式,比如上面的那组"\w{1 ...
- CF# 334 Lieges of Legendre
C. Lieges of Legendre time limit per test 2 seconds memory limit per test 256 megabytes input standa ...
- ccc 模拟重力 正太分布
ball.js cc.Class({ extends: cc.Component, properties: { x_vel:{ default:0 }, y_vel:{ default:0 }, gr ...