LeetCode--复原IP地址(面试手撕算法高频题)

题目描述:有效 IP 地址 正好由四个整数(每个整数位于 0255 之间组成,且不能含有前导 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 中的任何数字。你可以按 任何 顺序返回答案。
思路:将字符串装入StringBuilder中,对sb进行分割,如果满足合法的ip地址则加上'.' ,进行递归。
题解:

csharp 复制代码
private List<String> res = new ArrayList<>();
private StringBuilder path;
private int count = 0;
public List<String> restoreIpAddresses(String s) {
    path = new StringBuilder(s);
    backtracking(0);
    return res;
}
private void backtracking(int i) {
    // 终止条件,逗号的个数等于3
    if (count == 3) {
        // 判断第四段字符串是否是合法的IP地址
        if (isValid(path, i, path.length()-1)) {
            res.add(path.toString());
        }
        return;
    }
    for (int j = i; j < path.length(); j++) {
        // 判断是否是合法的IP地址
        if (isValid(path, i, j)) {
            // 插入逗号
            path.insert(j+1, '.');
            // 逗号计数器加一
            count++;
            // 递归+2 是因为插入了逗号,所以要跳过
            backtracking(j+2);
            // 回溯
            path.deleteCharAt(j+1);
            // 逗号计数器减一
            count--;
        }
    }
}
// 判断是否是合法的IP地址
private boolean isValid(StringBuilder s,int left ,int right) {
    // 判断长度
    if (left > right) {
        return false;
    }
    // 判断是否以0开头
    if (s.charAt(left) == '0' && left != right) {
        return false;
    }
    // 判断是否在0-255之间
    int num = 0;
    for (int i = left; i <= right; i++) {
        if (sb.charAt(i) >= '0' && sb.charAt(i) <= '9') {
            int temp = sb.charAt(i)-'0';
            num = num*10 + temp;
        } else {
            return false;
        }
    }
    return res >= 0 && res <= 255;
}
相关推荐
树下水月2 分钟前
PHP 一种改良版的雪花算法
算法·php·dreamweaver
一只数据集34 分钟前
全尺寸人形机器人灵巧手力觉触觉数据集-2908条ROSbag数据覆盖14大应用场景深度解析
大数据·人工智能·算法·机器人
罗西的思考2 小时前
【GUI-Agent】阿里通义MAI-UI 代码阅读(2)--- 实现
人工智能·算法·机器学习
刀法如飞3 小时前
TypeScript 数组去重的 20 种实现方式,哪一种你还不知道?
前端·javascript·算法
sali-tec4 小时前
C# 基于OpenCv的视觉工作流-章66-直线夹角
图像处理·人工智能·opencv·算法·计算机视觉
AC赳赳老秦4 小时前
接口测试自动化:用 OpenClaw 对接 Postman,实现批量回归测试、测试报告自动生成与推送
java·人工智能·python·算法·elasticsearch·deepseek·openclaw
_风满楼4 小时前
TDD实战-会议室冲突检测的红绿重构循环
前端·javascript·算法
pq2175 小时前
java实现遗传算法
算法
计算机安禾5 小时前
【计算机网络】第17篇:TCP拥塞控制的迭代——从Reno到CUBIC、BBR的理论转向
tcp/ip·计算机网络·php
书源丶5 小时前
四十三、网络编程(下)——TCP 编程与 HTTP 入门
java·网络·tcp/ip·http