题目描述:
原理:ip地址的每段可以看成是一个0-255的整数,把每段拆分成一个二进制形式组合起来,然后把这个二进制数转变成
一个长整数。
举例:一个ip地址为10.0.3.193
每段数字 相对应的二进制数
10 00001010
0 00000000
3 00000011
193 11000001
组合起来即为:00001010 00000000 00000011 11000001,转换为10进制数就是:167773121,即该IP地址转换后的数字就是它了。
需要对IP地址进行校验
Java实现:
import java.util.Scanner;
public class Main {
public static void main(String[] args) {
Scanner sc = new Scanner(System.in);
while (sc.hasNext()) {
String ip = sc.nextLine();
String num = sc.nextLine();
System.out.println(ipToNum(ip));
System.out.println(numToIp(Long.valueOf(num)));
}
}
private static long ipToNum(String ip) {
StringBuilder sb = new StringBuilder();
String[] ips = ip.split("\\.");
//System.out.println(Arrays.toString(ips));
for (int i = 0; i < ips.length; i++) {
if (Integer.valueOf(ips[i]) > 255 || Integer.valueOf(ips[i]) < 0)
return -1;
String tmp = Integer.toBinaryString(Integer.valueOf(ips[i]));
for (int j = 0; j < 8-tmp.length(); j++)
sb.append("0");
sb.append(tmp);
}
//System.out.println(sb.toString());
long num = Long.valueOf(sb.toString(), 2);
return num;
}
private static String numToIp(long num) {
String binaryStr = Long.toBinaryString(num);
StringBuilder sb = new StringBuilder();
int len = binaryStr.length();
while (len != 32) {
sb.append("0");
len++;
}
sb.append(binaryStr);
int a1 = Integer.valueOf(sb.substring(0, 8), 2);
int a2 = Integer.valueOf(sb.substring(8, 16), 2);
int a3 = Integer.valueOf(sb.substring(16, 24), 2);
int a4 = Integer.valueOf(sb.substring(24, 32), 2);
return a1 + "." + a2 + "." + a3 + "." + a4;
}
}
知识点:
- IP地址32为全为1时,要大于32位的整型,因此需要使用Long
- Integer.valueOf()可以将一个2进制串转换为整型
- Long.toBinaryString()可以将一个长整型转换为二进制串
- 要将IP地址按"."分隔时,需要转义\\,因为"."本身是正则表达式的一个占位符