华为OD:IPv4地址转换成整数

题目描述:

存在一种虚拟IPv4地址,由4小节组成,每节的范围为0-255,以#号间隔,虚拟IPv4地址可以转换为一个32位的整数,例如:

128#0#255#255,转换为32位整数的结果为2147549183(Ox8000FFFF)

1#0#0#0,转换为32位整数的结果为16777216 (0x01000000)

现以字符串形式给出一个虚拟IPv4地址,限制第1小节的范围为1-128,即每一节范围分别为(1-128)#(0-255)#(0-255)#(0-255),要求每个IPv4地址只能对应到唯一的整数上。

如果是非法IPv4,返回invalid IP

输入描述:

输入一行,虚拟IPv4地址格式字符串

输出描述:

输出一行,按照要求输出整型或者特定字符

用例:

|----|-------------|
| 输入 | 100#101#1#5 |
| 输出 | 1684340997 |
| 说明 | 无 |

代码:

java 复制代码
import java.util.Arrays;
import java.util.Scanner;
public class Main{
    public static void main(String[] args){
        Scanner sc=new Scanner(System.in);
        System.out.println(getResult(sc.nextline()));    
    }
    public static String getResult(String s){
        try{
            Integer[] ip = Arrays.stream(s.split('#')).map(Integer::parseInt).toArray(Integer[]::new);
            if(ip.length !=4)return "invalid IP";
            int p1 =ip[0],p2=ip[1],p3=ip[2],p4=ip[3];
            if(p1>=1 && p1<=128 && p2 >=0 && p2<=255 && p3>=0 && p3 <=255 && p4>=0 && p4<= 255 ){
                String tmp = getHexString(p1)+getHexString(p2)+ getHexString(p3) + getHexString(p4);
                return Long.parseLong(tmp,16)+"";                           
            } else{
                return "invalid IP";            
            }       
        }catch(Exception e){
            return "invalid IP";        
        }    
    }
    public static String getHexString(int num){
        String tmp = Integer.toHexString(num);
        if(tmp.length()< 2)tmp ="0" + tmp;
        return tmp;    
    }
}
相关推荐
TTGGGFF1 小时前
控制系统建模仿真(四):线性控制系统的数学模型
人工智能·算法
晚风吹长发1 小时前
初步了解Linux中的命名管道及简单应用和简单日志
linux·运维·服务器·开发语言·数据结构·c++·算法
Σίσυφος19002 小时前
Halcon中霍夫直线案例
算法
Anastasiozzzz2 小时前
leetcode力扣hot100困难题--4.俩个正序数列的中位数
java·算法·leetcode·面试·职场和发展
BHXDML3 小时前
第六章:推荐算法
算法·机器学习·推荐算法
Tisfy3 小时前
LeetCode 3510.移除最小数对使数组有序 II:有序集合
算法·leetcode·题解·设计·有序集合
汉克老师4 小时前
GESP2025年9月认证C++五级真题与解析(单选题9-15)
c++·算法·贪心算法·排序算法·归并排序·gesp5级·gesp五级
lihao lihao4 小时前
c++红黑树
算法
Sarvartha4 小时前
递推与递归笔记
算法
TracyCoder1235 小时前
LeetCode Hot100(1/100)——1. 两数之和 (Two Sum)
算法·leetcode