数字字符串转化成IP地址

文章介绍了两种方法来恢复IP地址的合法四段式表示。一种是暴力枚举法,通过三层循环遍历字符串的可能分割,检查每个部分是否为有效的0-255的整数且不以0开头。另一种是回溯法,从字符串的第一个字符开始,逐步构建每一段,递归地尝试所有可能的分割,直到找到所有合法的四段IP地址。
摘要由CSDN通过智能技术生成

题目描述

暴力枚举法

    vector<string> restoreIpAddresses(string s) {
        vector<string> res;
        int n=s.length();
        for(int i=0;i<3&&i<n-3;++i){
            for(int j=i+1;j<i+4&&j<n-2;++j){
                for(int k=j+1;k<j+4&&k<n-1;++k){
                    if(n-1-k>3) continue;
                    string a=s.substr(0,i+1);
                    string b=s.substr(i+1,j-i);
                    string c=s.substr(j+1,k-j);
                    string d=s.substr(k+1,n-1-k);
                    if(stoi(a)>255||stoi(b)>255||stoi(c)>255||stoi(d)>255) continue;
                    if((a.length()>1&&a[0]=='0')||(b.length()>1&&b[0]=='0')||(c.length()>1&&c[0]=='0')||(d.length()>1&&d[0]=='0')) continue;
                    string temp=a+'.'+b+'.'+c+'.'+d;
                    res.push_back(temp);
                }
            }
        }
        return res;
    }

回溯法

class Solution {
private:
    vector<string> res;
    string s;
    string nums;
public:
    void dfs(int step,int index){//index表示当前串起始下标,step表示已分出数字数量
        if(step==4){
            if(index==s.length()) res.push_back(nums);
            return;
        }
        string cur="";
        int n=s.length();
        for(int i=index;i<index+3&&i<n-3+step;++i){//枚举,这里n写出s.length()会出错?qAq?
            cur+=s[i];
            string temp=nums;
            if(stoi(cur)<=255&&(cur[0]!='0'||cur.length()==1)){
                nums+=cur;
                if(step<3) nums+='.';
                dfs(step+1,i+1);//递归
                nums=temp;//复原
            }
        }
    }
    vector<string> restoreIpAddresses(string s) {
        this->s=s;//类指针->类变量
        dfs(0,0);
        return res;
    }
};
### 回答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、付费专栏及课程。

余额充值