版权声明:本文为博主原创文章,未经博主允许不得转载。 https://blog.csdn.net/qq_36367789/article/details/78734386
IP地址总是由4个0-255的数字以”.”隔开的形式来显示给用户,例如192.168.0.1。在计算机中,一个IP地址用4字节来依次存储其从右到左的4个数字部分,每个字节(8比特)以2进制的形式存储相应的IP地址数字,请你实现一个从IP地址的显示格式到计算机存储格式的转换。
Input
每行输入一个IP地址,如果输入为-1,结束输入Output
每行输出一个IP地址在计算机存储中以二进制表示的4字节内容Sample Input
192.168.0.1
255.255.0.0
1.0.0.1
-1Sample Output
11000000101010000000000000000001
11111111111111110000000000000000
00000001000000000000000000000001
import java.util.ArrayList;
import java.util.List;
import java.util.Scanner;
/**
* Created by Fant.J.
* 2017/12/6 19:20
*/
public class Main {
private static String ipAddr = null;
//用来存储ip转换成二进制的字符串
private static String result = "";
//用来存储result集合
private static List list = new ArrayList();
//count:用来协助计算字节数。一个ip分四段,第一段转换二进制完成后result长度是1*8,第二段是2*8...
private static int count = 1;
public static void main(String []args){
Scanner scanner = new Scanner(System.in);
ipAddr = scanner.nextLine();
while (! ipAddr.contains("-1")){
String[] datas = ipAddr.split("\\.");
int data1 = Integer.valueOf(datas[0]);
int data2 = Integer.valueOf(datas[1]);
int data3 = Integer.valueOf(datas[2]);
int data4 = Integer.valueOf(datas[3]);
//将获取的四个ip段分别交给pincou(拼凑)方法处理成二进制并倒序相加成字符串类型
pincou(data4);
pincou(data3);
pincou(data2);
pincou(data1);
//将当前ip转换成的result字符串存入list集合
list.add(result);
//初始化 三个参数
result="";
count = 1;
ipAddr = scanner.nextLine();
}
for (Object item:list){
System.out.println(item);
}
}
public static void pincou(int data){
while (true){
int yushu = data%2;
result = yushu+result;
data /= 2;
if (data==0){
//获取当前result字符串长度
int judge = result.length();
//判断下是否够8*count个字节,如果不够就在前面补0
if (judge<8*count){
for (int i = 0;i<8*count-judge;i++){
result = 0+result;
}
}
count++;
break;
}
}
}
}
做的过程中有个逻辑错误,找了好长时间分享给大家。
就是在获取result长度当作for循环条件的时候。我起初是用result.lenth() 获取。导致字节数不够8(不满足我的要求)就运行下面程序。之后我先把这个长度赋值给变量judge,然后在做循环。希望大家以后用循环,切忌把动态改变的东西当作条件来判断