算法-回溯-14

力扣-真题-复原IP地址

IP地址, 一个数字 转换成四个, 需要用三个标点符号,

其实就是三次选择, 选择的位置不能 一样,

同时 这个标点符号 前的数字 需要满足

  • 前缀不能为0 ,
  • 数字 在 0 到 255 (当 字符串的长度大于3 直接break),
  • 然后 递归截止的条件是 三次选择做完 ,
  • 同时需要注意 剩下的位数, 应该足够后面剩下 的数字数量, 比如 计算 第一个数字的时候, 就需要保留至少3位数 ,少了 就不可能拼成IP。
    代码如下
java 复制代码
public static List<String> restoreIpAddresses(String s) {
        List<String> result = new ArrayList<>();
        getResult(0 , 0 , s , result , "");
        return result;
    }


    public static void getResult(int pointNum , int  index ,  String s , List<String> result, String temResult){
        if (pointNum == 3 ){
            String substring = s.substring(index );
            if (substring.length() > 1 && substring.charAt(0) == '0') return;
            if (substring.length() > 3 ) return;
            int i = Integer.parseInt(substring);
            if (i > 255 ) return;
            result.add(temResult + substring);
            return;
        }

        for (int i = index; i < s.length(); i++) {
            int size = 3 - pointNum;
            if (size > s.length() - i - 1) break;
            String tem = s.substring(index, i + 1);
            System.out.println(tem);
            if (tem.length() > 1 && tem.charAt(0) == '0') break;
            int temNum = Integer.parseInt(tem);
            if (temNum > 255) break;
            getResult(pointNum + 1, i + 1, s, result, temResult + tem + ".");
        }
    }

复杂度

时间复杂度:O(1) - 固定的递归深度

因为对于一个IP地址,最多只能有3个点,每个点最多分割3位数字,所以递归的深度是固定的,最多只有4段,每段最多3个字符。这意味着递归的路径数量是有限的,不会随着输入字符串长度无限增长

空间复杂度:O(1) - 固定的递归深度和有限的结果数量

相关推荐
FQNmxDG4S1 小时前
Java多线程编程:Thread与Runnable的并发控制
java·开发语言
超级码力6661 小时前
【Latex文件架构】Latex文件架构模板
算法·数学建模·信息可视化
穿条秋裤到处跑1 小时前
每日一道leetcode(2026.04.29):二维网格图中探测环
算法·leetcode·职场和发展
前端老石人1 小时前
HTML 字符引用完全指南
开发语言·前端·html
matlab_xiaowang2 小时前
Redux 入门:JavaScript 可预测状态管理库
开发语言·javascript·其他·ecmascript
Merlos_wind2 小时前
HashMap详解
算法·哈希算法·散列表
虹科网络安全2 小时前
艾体宝干货|数据复制详解:类型、原理与适用场景
java·开发语言·数据库
axng pmje2 小时前
Java语法进阶
java·开发语言·jvm
汉克老师2 小时前
GESP2025年3月认证C++五级( 第三部分编程题(1、平均分配))
c++·算法·贪心算法·排序·gesp5级·gesp五级
rKWP8gKv72 小时前
Java微服务性能监控:Prometheus与Grafana集成方案
java·微服务·prometheus