原理:ip地址的每段可以看成是一個0-255的整數,把每段拆分成一個二進制形式組合起來,然後把這個二進制數轉變成一個長整數。
舉例:一個ip地址爲10.0.3.193
每段數字 相對應的二進制數
10 00001010
0 00000000
3 00000011
193 11000001
組合起來即爲:00001010 00000000 00000011 11000001,轉換爲10進制數就是:167773121,即該IP地址轉換後的數字就是它了。
每段可以看成是一個0-255的整數,需要對IP地址進行校驗
輸入描述:
輸入 1 輸入IP地址 2 輸入10進制型的IP地址
輸出描述:
輸出 1 輸出轉換成10進制的IP地址 2 輸出轉換後的IP地址
輸入例子:
10.0.3.193
167969729
輸出例子:
167773121
10.3.3.193
解題思路
10.0.3.193進行二進制解析的時候,不到8位的時候在前面補0。然後在利用解析函數進行解析
167969729先轉化成二進制,再最高位不到32位時進行添加0,然後8位8位進行二進制解析,就可以了。
最後說一句。Java函數庫真的很強大。
import java.util.*;
public class Main {
public static void main(String[] args) {
Scanner sc = new Scanner(System.in);
while (sc.hasNext()) {
String s1 = sc.nextLine();
String num = sc.nextLine();
String[] split = s1.split("\\.");
StringBuilder sb = new StringBuilder();
for (int i = 0; i < split.length; i++) {
String s = Integer.toBinaryString(Integer.valueOf(split[i]));
int diff = 0;
if (s.length() < 8) {
diff = 8 - s.length();
}
StringBuilder stringBuilder = new StringBuilder();
for (int j = 0; j < diff; j++) {
stringBuilder.append("0");
}
stringBuilder.append(s);
sb.append(stringBuilder);
}
Long sum = Long.parseLong(sb.toString(), 2);
System.out.println(sum);
//10
String bin = Long.toBinaryString(Long.parseLong(num)); //長整形整數轉爲二進制
if (bin.length() < 32) {
int diff = 32 - bin.length();
StringBuilder sb1 = new StringBuilder();
for (int i = 0; i < diff; i++) {
sb1.append("0");
}
bin = sb1.toString() + bin;
}
StringBuilder stringBuilder1 = new StringBuilder();
String substring = bin.substring(0, 8);
String substring1 = bin.substring(8, 16);
String substring2 = bin.substring(16, 24);
String substring3 = bin.substring(24, 32);
stringBuilder1.append(Integer.valueOf(substring, 2) + ".");
stringBuilder1.append(Integer.valueOf(substring1, 2) + ".");
stringBuilder1.append(Integer.valueOf(substring2, 2) + ".");
stringBuilder1.append(Integer.valueOf(substring3, 2));
System.out.println(stringBuilder1);
}
}
}