当前位置: 首页 > article >正文

LeetCode 93-复制 IP地址

题目链接:LeetCode93

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

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;
    }
}

http://www.kler.cn/a/390807.html

相关文章:

  • 快速导入请求到postman
  • Zstandard压缩算法
  • 计算机的错误计算(二百零七)
  • 1. npm 常用命令详解
  • Tauri教程-基础篇-第二节 Tauri的核心概念上篇
  • MySQL - 子查询和相关子查询详解
  • MYSQL知识总结
  • uni-app选项卡制作 ⑥
  • 【网络安全渗透测试零基础入门】之SNMP放大攻击原理及实战演示,零基础入门到精通,收藏这一篇就够了!
  • 【c语言】memmove函数的使用和模拟实现
  • 【Linux】获得同一子网下当前在线设备IP/Latency/MAC 通过nmap指定CIDR扫描当前在线设备
  • Redis在docker中的主从,哨兵配置
  • kafka消费者的消费分区策略有哪些,默认是哪个?
  • C#-命名空间
  • qsqlmysql.lib的编译和使用
  • Java接收xml格式参数转为json
  • sql注入基础知识
  • 海柔仿真系统存储实践:混合云架构下实现高可用与极简运维
  • 【cft.show-web3解题思路】-php://input伪协议
  • 行业类别-金融科技-子类别区块链技术-细分类别智能合约-应用场景供应链金融课题
  • Python 正则表达式使用指南
  • Vue页面假死点不动现象Cannot read properties of undefined(reading ‘_wrapper‘)报错
  • 如何在Linux中使用Cron定时执行SQL任务
  • ROM修改进阶教程------安卓14 安卓15去除app签名验证的几种操作步骤 详细图文解析
  • 机器学习(基础2)
  • HCIP-快速生成树RSTP