题目地址(93. 复原 IP 地址)
https://leetcode-cn.com/problems/restore-ip-addresses/
题目描述
有效 IP 地址 正好由四个整数(每个整数位于 0 到 255 之间组成,且不能含有前导 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 中的任何数字。你可以按 任何 顺序返回答案。示例 1:输入:s = "25525511135"输出:["255.255.11.135","255.255.111.35"]示例 2:输入:s = "0000"输出:["0.0.0.0"]示例 3:输入:s = "1111"输出:["1.1.1.1"]示例 4:输入:s = "010010"输出:["0.10.0.10","0.100.1.0"]示例 5:输入:s = "101023"输出:["1.0.10.23","1.0.102.3","10.1.0.23","10.10.2.3","101.0.2.3"]提示:0 <= s.length <= 20s 仅由数字组成
前置知识
公司
- 暂无
思路
关键点
Java Code:
class Solution {ArrayList<String> res = new ArrayList<>();public List<String> restoreIpAddresses(String s) {//不符合规范的直接剪枝if (s.length() > 12 || s.length() < 4) {return res;}loop(s, 0 , 0);return res;}//s 给定的字符串 startIndex 代表开始循环的位置 pointIndex代表.的数量void loop(String s , int startIndex , int pointIndex){//判断终止条件 IP总共4段 pointIndex为3就是最后一段if (pointIndex == 3) {//判断最后一段是否合法 合法就加入返回值列表if (isValid(s, startIndex, s.length() - 1)) {res.add(s);}return;}//一层的循环 每次让startIndex+1知道循环完整个字符串for (int i = startIndex; i < s.length(); i++) {//判断是否合法if (isValid(s, startIndex, i)) {//假设s为123 i= 0 s = 1.23s = s.substring(0, i+1) + "." + s.substring(i+1);//.的数量++pointIndex ++;//从.的后面开始下一层的递归loop(s, i + 2 ,pointIndex);//回溯pointIndex -- ;//回溯 去掉. 继续循环 下一次就是12.3s = s.substring(0,i+1)+s.substring(i+2);} else {//不合法就跳过本次循环break;}}}//判断是否合法boolean isValid(String s, int start, int end) {if (start > end) {return false;}//情况1 开头数字不能为0if (s.charAt(start) == '0' && start != end) {return false;}//情况2 不能为非数字 每段数字不能大于255int sum = 0;for (int i = start; i <= end; i++) {if (s.charAt(i) > '9' || s.charAt(i) < '0') {return false;}//情况3 每段数字不能大于255sum = sum * 10 + (s.charAt(i) - '0');if (sum > 255) {return false;}}return true;}}
复杂度分析
令 n 为数组长度。
- 时间复杂度:
#card=math&code=O%28n%29&id=a7uQl)
- 空间复杂度:
#card=math&code=O%28n%29&id=cBN1n)
