leetcode 93. 复原 IP 地址

leetcode 93. 复原 IP 地址

题目

有效 IP 地址 正好由四个整数(每个整数位于 0 到 255 之间组成,且不能含有前导 0),整数之间用 ‘.’ 分隔。

例如:“0.1.2.201” 和 “192.168.1.1” 是 有效 IP 地址,但是 “0.011.255.245”、“192.168.1.312” 和 “192.168@1.1” 是 无效 IP 地址。
给定一个只包含数字的字符串 s ,用以表示一个 IP 地址,返回所有可能的有效 IP 地址,这些地址可以通过在 s 中插入 ‘.’ 来形成。你 不能 重新排序或删除 s 中的任何数字。你可以按 任何 顺序返回答案。

示例 1:

输入:s = “25525511135”
输出:[“255.255.11.135”,“255.255.111.35”]
示例 2:

输入:s = “0000”
输出:[“0.0.0.0”]
示例 3:

输入:s = “101023”
输出:[“1.0.10.23”,“1.0.102.3”,“10.1.0.23”,“10.10.2.3”,“101.0.2.3”]

提示:

1 <= s.length <= 20
s 仅由数字组成

思路

实际上乍一看就是分割字符串的翻版,但中间实验室项目插入,三周后重新捡起来这道题,我历经多次debug,终于做出来了。实际上需要考虑的有如下几点:

  1. 只能切成4段
  2. 要考虑每一段最多有3位数字
  3. 可能有00这样的数字,记得处理好,如果遇到开头是0的直接自成一段了
  4. 返回条件有两个,一个是插入了达到数量的’.'另一个是字符串遍历到结尾了。但只有这两点同时满足才是结果集的答案

题解

class Solution {
    List<String> list = new ArrayList<>();
    char[] str;
    int cnt;
    int idx;

    public List<String> restoreIpAddresses(String s) {
        // 开的大小也有讲究的,需要让其能容纳4个'.'
        str = new char[s.length() + 4];
        dfs(s, 0);
        return list;
    }

    public void dfs(String s, int st) {
        //满足限制条件4
        if (cnt >= 4 || st == s.length()) {
        	// 需要理解为什么是idx-1,因为最终结尾时候我插入的是4个'.',需要去掉一个
            if (st == s.length() && cnt == 4) {list.add(new String(str, 0, idx - 1));}
            return;
        }
        // 满足限制条件3
        if (s.charAt(st) == '0') {
                str[idx++] = '0';
                str[idx++] = '.';
                cnt++;
                dfs(s, st + 1);
                idx -= 2;
                cnt--;
        }
        else {
            // i-st<3为了满足限制2
            for (int i=st;i<s.length()&&i-st<3;i++) {
                int tmp = Integer.valueOf(s.substring(st, i+1));
                if (tmp < 256) {
                    for (int j=st;j<i+1;j++,idx++) {
                        str[idx] = s.charAt(j);
                    }
                    str[idx++] = '.';
                    cnt++;
                    dfs(s, i + 1);
                    idx = idx - 1 - (i + 1 - st);
                    cnt--;
                }
            }
        }        
    }
}

相关推荐

  1. leetcode93. 复原 IP 地址

    2024-01-06 13:18:04       27 阅读
  2. leetcode 93. 复原 IP 地址

    2024-01-06 13:18:04       47 阅读
  3. LeetCode 93. 复原 IP 地址

    2024-01-06 13:18:04       27 阅读
  4. LeetCode 93. 复原 IP 地址

    2024-01-06 13:18:04       20 阅读
  5. leetcode93.复原IP地址

    2024-01-06 13:18:04       17 阅读
  6. LeetCode 93.复原IP地址 Python题解

    2024-01-06 13:18:04       40 阅读

最近更新

  1. TCP协议是安全的吗?

    2024-01-06 13:18:04       17 阅读
  2. 阿里云服务器执行yum,一直下载docker-ce-stable失败

    2024-01-06 13:18:04       16 阅读
  3. 【Python教程】压缩PDF文件大小

    2024-01-06 13:18:04       15 阅读
  4. 通过文章id递归查询所有评论(xml)

    2024-01-06 13:18:04       18 阅读

热门阅读

  1. python中使用socket服务发送接收图像

    2024-01-06 13:18:04       32 阅读
  2. Jtti:为什么建议企业使用存储型服务器?

    2024-01-06 13:18:04       35 阅读
  3. A Tour of Go部分练习

    2024-01-06 13:18:04       40 阅读
  4. 设置模式:适配器模式

    2024-01-06 13:18:04       34 阅读
  5. Linux平台下gcc安装升级

    2024-01-06 13:18:04       44 阅读
  6. Kendo UI for Angular 学习笔记

    2024-01-06 13:18:04       42 阅读
  7. Redhat(liunx)连接虚拟机

    2024-01-06 13:18:04       23 阅读
  8. 阿里的通义灵码在android studio上的使用方法

    2024-01-06 13:18:04       52 阅读
  9. 07GoF之工厂模式

    2024-01-06 13:18:04       27 阅读
  10. K8S三种发布方式和声明式资源管理

    2024-01-06 13:18:04       32 阅读