LeetCode 93-复制 IP地址

题目链接:LeetCode93

欢迎留言交流,每天都会回消息。

java 复制代码
class Solution {
    //定义结果集,返回最终结果
    List<String> rs = new ArrayList<>();
    public List<String> restoreIpAddresses(String s) {
        //将字符串包装为可变长度的字符串
        StringBuilder sb = new StringBuilder(s);
        backTracking(sb, 0, 0);
        return rs;
    }
    //sb:传入的字符串
    //startIdx:用于记录在那个位置分割字符串
    //dotCount:IP中 '.' 的个数
    void backTracking(StringBuilder sb, int startIdx, int dotCount){
        //'.'的个数为3的时候
        if(dotCount == 3){
            //判断最后一个 '.' 后面剩余的字符是否复合规则
            if(isValid(sb, startIdx, sb.length() - 1)){
                rs.add(sb.toString());
            }
            return;
        }

        for(int i = startIdx; i < sb.length(); i++){
            //如果字符合法
            if(isValid(sb, startIdx, i)){
                //字符后面插入'.'
                sb.insert(i + 1, '.');
                //递归
                backTracking(sb, i + 2, dotCount + 1);
                //回溯
                sb.deleteCharAt(i + 1);
            }else{
                break;
            }
        }
    }

    //判断start到end这段字符是否为有效的字符
    private boolean isValid(StringBuilder s, int start, int end){
        if(start > end){
            return false;
        }
        //首字母为零,而且字母数大于等于2的字串:013 
        if(s.charAt(start) == '0' && start != end){
            return false;
        }
        int num = 0;
        //遍历start到end字符将字符转换为数字,将数值和255比较大小
        for(int i = start; i <= end; i++){
            int digit = s.charAt(i) - '0';
            num = num * 10 + digit;
            if(num > 255){
                return false;
            }
        }
        return true;
    }
}
相关推荐
步步为营DotNet2 分钟前
深度探索.NET 中ValueTask:优化异步性能的轻量级利器
java·spring·.net
栈与堆5 分钟前
LeetCode-88-合并两个有序数组
java·开发语言·数据结构·python·算法·leetcode·rust
董世昌418 分钟前
添加、删除、替换、插入元素的全方法指南
java·开发语言·前端
源代码•宸13 分钟前
Leetcode—712. 两个字符串的最小ASCII删除和【中等】
开发语言·后端·算法·leetcode·职场和发展·golang·dp
小当家.10514 分钟前
JVM八股详解(上部):核心原理与内存管理
java·jvm·学习·面试
heartbeat..14 分钟前
Spring 声明式事务:原理、使用及失效场景详解
java·spring·面试·事务
寻星探路15 分钟前
【Python 全栈测开之路】Python 基础语法精讲(三):函数、容器类型与文件处理
java·开发语言·c++·人工智能·python·ai·c#
xiaolyuh12317 分钟前
【XXL-JOB】执行器 Netty服务 & Tomcat 进程+资源共用详解
java·tomcat
无限进步_17 分钟前
【C语言&数据结构】相同的树:深入理解二叉树的结构与值比较
c语言·开发语言·数据结构·c++·算法·github·visual studio
jasnet_u20 分钟前
SpringCloudAlibaba的web微服务快速搭建
java·springboot·springlcoud