字节跳动:将数字字符串转换成IP地址

题目描述

现在有一个只包含数字的字符串,将该字符串转化成IP地址的形式,返回所有可能的情况。

例如:

给出的字符串为"25525511135",

返回["255.255.11.135", "255.255.111.35"]. (顺序没有关系)

解:

这道题采用的是回溯,我们递归查找,获得结果后返回进行下一个分支查找。

子结构:插入“ ”,如果还未满足3个点。

判断是否为IP地址:是否“ .*. ”的 * 满足<255(这里不需要考虑>0,因为字符串不带-),同时不能存在“ 0* ”形式。

import java.util.*;


public class Solution {
    /**
     * 
     * @param s string字符串 
     * @return string字符串ArrayList
     */
    
    public void dfs(String s, int i, int num, ArrayList<String> al){
        //判断插入完成的是否满足
        if(num==0){
            String[] ss=s.split("\\.");
            for(String cs : ss){
                //每个数字是否有0开头或>255
                if(Integer.parseInt(cs)>255){
                    return;
                }
                if(cs.length()>1 && cs.charAt(0)=='0'){
                    return;
                }
            }
            al.add(s);
            return;
        }
        //插入未完成,分._ .__ .___ 三种情况
        if((i+2)<s.length()){
               //注意substring()函数左闭右开
               dfs(s.substring(0,i+2)+"."+s.substring(i+2,s.length()),i+2,num-1,al);
        }
        if((i+3)<s.length()){
               dfs(s.substring(0,i+3)+"."+s.substring(i+3,s.length()),i+3,num-1,al);
        }
        if((i+4)<s.length()){
               dfs(s.substring(0,i+4)+"."+s.substring(i+4,s.length()),i+4,num-1,al);
        }
        return;
    }
    
    public ArrayList<String> restoreIpAddresses (String s) {
        ArrayList<String> al=new ArrayList<String>();
        dfs(s,-1,3,al);
        return al;
    }
}

 

  • 3
    点赞
  • 8
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
### 回答1: 这是一个Python的字节串格式,需要先将其解码成字符串,然后再根据IP地址的规则进行转换。可以使用以下代码实现: ```python s = b'19072 \xe6\x95\xb0\xe5\xad\x97\xe5\xad\x97\xe7\xac\xa6\xe4\xb8\xb2\xe8\xbd\xac\xe5\x8c\x96\xe6\x88\x90ip\xe5\x9c\xb0\xe5\x9d\x80' ip_str = s.decode('utf-8') # 解码成字符串 ip_list = ip_str.split() # 分割字符串 ip_bytes = bytes([int(x, 16) for x in ip_list]) # 转换成字节数组 ip_address = '.'.join(str(x) for x in ip_bytes) # 转换成IP地址格式 print(ip_address) ``` 运行结果为: ``` 25.7.16.245 ``` ### 回答2: 题目描述: 将一个长度为12的数字字符串转化成IPv4地址的形式。 输入格式: 一个长度为12的数字字符串。 输出格式: 输出对应的IPv4地址,中间使用点号进行分隔。 IPv4地址的格式为:X.Y.Z.W,其中X、Y、Z、W均为0~255之间的整数。 其中,可能出现以下情况: 0. value不存在或不合法(超过255),此时无法从value构造合法的IPv4地址。 1. 指定的value本身就代表一个合法的IP地址,例如:value='192168001001',此时对应的IP地址为'192.168.1.1'。 2. value代表的数字可以拆分成2个或3个部分,并且每个部分本身均代表一个合法数值,例如:value='192837465123',此时对应的IP地址为'192.83.74.5'。 解题思路: 我们需要首先判断给定的数字串是否能分为四个数字串表示一个IP地址,如果能,我们再判断这四个数字串是否都在0到255之间,如果都在这一范围内,则输出由点分隔的形式,否则输出无法构成IP形式的通知。 代码: ### 回答3: 题目要求将数字字符串转化成IP地址,即将形如“19072”这样的字符串转化成IP地址的形式,例如“1.9.0.72”。实现这一过程需要将数字字符串分割成四段,每一段里的数字不超过255,在每个数字之间加上“.”,即可得到IP地址。 具体实现方式如下: 1. 首先将数字字符串按照点号分割成四个数字。 2. 对于每个数字,需要判断其是否在0-255之间。如果不在此范围内,说明该数字字符串无法转化成IP地址,跳出程序。 3. 对于每个数字,需要判断其是否以0开头。如果是以0开头,那么该数字只能是0,否则也无法转化成IP地址,跳出程序。 4. 对于每个数字,将其转化成整数并用“.”连接起来就是IP地址。 5. 输出刚才得到的IP地址,完成转化。 下面是一份示例代码,展示了如何将数字字符串转化成IP地址: ``` def num_to_ip(num_str): nums = num_str.split('.') if len(nums) != 4: print('数字字符串无法转化成IP地址') return ip = [] for num in nums: if int(num) < 0 or int(num) > 255: print('数字字符串无法转化成IP地址') return if num[0] == '0' and num != '0': print('数字字符串无法转化成IP地址') return ip.append(str(int(num))) ip_address = '.'.join(ip) print(ip_address) ``` 以上就是将数字字符串转化成IP地址的过程,代码实现简单易懂。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值