华为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;    
    }
}
相关推荐
深圳佛手26 分钟前
几种限流算法介绍和使用场景
网络·算法
陌路201 小时前
S14排序算法--基数排序
算法·排序算法
ysa0510301 小时前
虚拟位置映射(标签鸽
数据结构·c++·笔记·算法
Yue丶越1 小时前
【C语言】深入理解指针(二)
c语言·开发语言·数据结构·算法·排序算法
m0_748248021 小时前
C++中的位运算符:与、或、异或详解
java·c++·算法
沐浴露z1 小时前
详解【限流算法】:令牌桶、漏桶、计算器算法及Java实现
java·算法·限流算法
王哈哈^_^2 小时前
【完整源码+数据集】草莓数据集,yolov8草莓成熟度检测数据集 3207 张,草莓成熟度数据集,目标检测草莓识别算法系统实战教程
人工智能·算法·yolo·目标检测·计算机视觉·视觉检测·毕业设计
油泼辣子多加2 小时前
【实战】自然语言处理--长文本分类(3)HAN算法
算法·自然语言处理·分类
Shinom1ya_2 小时前
算法 day 46
数据结构·算法
夏鹏今天学习了吗3 小时前
【LeetCode热题100(64/100)】搜索旋转排序数组
算法·leetcode·职场和发展