首页 > 其他分享 >刷刷刷 Day 28 | 93. 复原 IP 地址

刷刷刷 Day 28 | 93. 复原 IP 地址

时间:2023-01-29 22:11:49浏览次数:58  
标签:dotSum return int IP 28 地址 startIndex 93

93. 复原 IP 地址

LeetCode题目要求

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

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

示例

输入:s = "25525511135"
输出:["255.255.11.135","255.255.111.35"]
解题思路

本题虽然是分割串,但是和组合是非常类似的。那么依然可以按照回溯三部曲来处理。
首先我们需要一个校验数字合法性的逻辑,这里主要针对的是ip,有以下规则:

  1. 不能以 0 开头
  2. 只能是 0 - 9 的数字
  3. 大于等于 0 且 小于等于255
    接着根据递归三部曲
  4. 方法 void backtracking(String s, int startIndex, int dotSum); startIndex 是分隔的索引, dotSum 计算增加‘点’ 号的数量,3 个 ‘点’ 号即可把串分成 4 段
  5. 终止条件,经过判断与增加 3 个 ‘点’ 号后,分成了 4 段,此时前三段已经是合法的,那么需要处理第 4 段是否合法,如果符合那么就放入结果集,并 return
  6. 单层逻辑,每次分隔判断是否合法,合法就切割并增加 ‘点’ 号,dotSum 计数;之后进行递归;再回溯操作

上代码

class Solution {
    private List<String> res = new ArrayList<>();
    public List<String> restoreIpAddresses(String s) {
        if (s.length() > 12) {
            return res;
        }
        backtracking(s, 0, 0);
        return res;
    }

    private void backtracking(String s, int startIndex, int dotSum) {
        if (dotSum == 3) {
            // 当点符号数量为3时,本次分隔结束,然后判断第4段是否合法
            if (isIP(s, startIndex, s.length() - 1)) {
                // 存储结果
                res.add(s);
            }
            return;
        }

        for (int i = startIndex; i < s.length(); i++) {
            // 分割串判断是否合法
            if (isIP(s, startIndex, i)) {
                s = s.substring(0, i + 1) + "." + s.substring(i + 1);
                dotSum++;
                backtracking(s, i + 2, dotSum);
                // 回溯
                dotSum--;
                s = s.substring(0, i + 1) + s.substring(i + 2);
            } else {
                break;
            }

        }
    }

    private boolean isIP(String s, int begin, int end) {
        if (begin > end) {
            return false;
        }

        // 0 开头的不合法, 取第一个为 0,并且不止 1个
        if (s.charAt(begin) == '0' && begin != end) {
            return false;
        }
        // 不是数字的不合法
        int num = 0;
        for (int i = begin; i <= end; i++) {
            // 不在0-9之间,非数字
            if (s.charAt(i) > '9' || s.charAt(i) < '0') {
                return false;
            }
            // 计算数,每次 乘 10 得到一个数
            num = num * 10 + (s.charAt(i) - '0');
            // 判断上述计算的数是否在 255 内,超过 255 的不合法
            if (num > 255) {
                return false;
            }
        }
        return true;
    }
}
重难点

依旧是回溯三部曲,及对于分隔索引的处理

附:学习资料链接

标签:dotSum,return,int,IP,28,地址,startIndex,93
From: https://www.cnblogs.com/blacksonny/p/17073958.html

相关文章

  • 邮件端口25、109、110、143、465、995、993、994
    全部常用邮件端口25、109、110、143、465、995、993、994全部常用邮件端口有:25、109、110、143、465、995、993等,常见各大邮箱协议和端口见下方 1)发邮件协议和端口:A......
  • JavaScript学习笔记—DOM之元素节点
    元素节点对象(element)在网页中,每一个标签都是一个元素节点如何获取元素节点对象?通过document对象来获取元素节点通过document对象来创建元素节点通过document来获......
  • P1014 [NOIP1999 普及组] Cantor 表
    题目链接:https://www.luogu.com.cn/problem/P1014有理数可枚举In1873Cantorprovedtherationalnumberscountable,i.e.theymaybeplacedinone-onecorrespon......
  • python-pip
    一、pip介绍Python官网中的安装包中已经自带了pip,在安装时默认选择安装。安装完python后需要手动配置pip的环境变量,cmd命令可以查看pip是否可用:pip或者pip-h二、命令......
  • [Typescript] Understanding Generics at Different Levels of Functions
    Thefollowingcodeimport{expect,it}from'vitest';import{Equal,Expect}from'../helpers/type-utils';exportinterfaceCache<T>{get:(key:string......
  • (AtCoder Beginner Contest 287)(D 字符串前后缀合并匹配)(E Trie求最长公共前缀(LCP)
    D-MatchorNot(字符串前后缀合并匹配)题目大意:给定两个字符串S和T,对于每个x=0,1,2...|T|求S的子串(前x个字符和后|T|-x个字符在不改变顺序的情况下组成)是否与T相......
  • JavaScript中实现sleep睡眠函数的几种简单方法(转)
    转自:JavaScript中实现sleep睡眠函数的几种简单方法一.什么是sleep函数?sleep是一种函数,他的作用是使程序暂停指定的时间,起到延时的效果。javascript好像诶呦提供sleep工......
  • TypeScript踩坑记录
    设置experimentalDecorators无效errorTS1219:Experimentalsupportfordecoratorsisafeaturethatissubjecttochangeinafuturerelease.Setthe'experi......
  • POJ--3723 Conscription(最小生成树)
    记录18:302023-1-29http://poj.org/problem?id=3723reference:《挑战程序设计竞赛(第2版)》2.5.6p109DescriptionWindyhasacountry,andhewantstobuildana......
  • 「解题报告」ARC136F Flip Cells
    感觉AtCoder上高于铜的难度就完全是随机了,这题完全是金吧,怎么可能只有铜啊,我快写自闭了。以下记\(n=hw\)。我们设三个DP数组:\(f_i\)为从初始状态经过\(i\)步之......