第93题:复原IP地址
一. 问题描述
给定一个只包含数字的字符串,复原它并返回所有可能的 IP 地址格式。
示例:
输入: "25525511135"
输出: ["255.255.11.135", "255.255.111.35"]
二. 解题思路
本题思路:采用回溯算法进行求解,建立递归函数(全局变量list存储IP地址,局部变量data存储剩下的字符串,length存储当前需要填的位数,数组nums存储ip中各个段的值)
步骤一:建立递归函数,判断,当nums数组最后一位数组满足要求则将数组按照格式要求存储到list中,否则,进入步骤二。
步骤二:进行回溯算法,依次从data中取出数字,判断其是否小于256且大于等于0,则将其添加到nums[length]中,在data中删除该数字,继续递归,返回步骤一。
步骤三:这道题需要注意细节,00,001这种情况和数字的界限问题,所以要考虑周全。
三. 执行结果
执行用时 :3 ms, 在所有 java 提交中击败了89.68%的用户
内存消耗 :36.3 MB, 在所有 java 提交中击败了48.81%的用户
四. Java代码
class Solution {
public List<String> restoreIpAddresses(String s) {
List<String> list=new ArrayList<String>();
int []nums= {-1,-1,-1,-1};
address(list,s,0,nums);
return list;
}
public void address(List<String> list,String data,int length,int []nums) {
if(nums[3]<256&&nums[3]>=0&&data.length()<=0){
String temp="";
for(int i=0;i<4;i++) {
temp=temp+nums[i];
if(i<3)
temp=temp+".";
}
list.add(temp);
}
if(length==4&&data.length()>=4){
return;
}
String tem="";
for(int j=0;j<3&&j<data.length()&&length<4&&data.length()>0;j++){
tem=tem+data.charAt(j);
int temdata=Integer.parseInt(tem);
if(tem.charAt(0)=='0'&&tem.length()>1){
continue;
}
if(temdata<256&&temdata>=0) {
String getdata=data.substring(j+1,data.length() );
int []num= {-1,-1,-1,-1};
System.arraycopy(nums, 0, num, 0, num.length);
num[length]=temdata;
address(list,getdata,length+1,num);
}
}
}
}
第93题:复原IP地址的更多相关文章
- LeetCode:复原IP地址【93】
LeetCode:复原IP地址[93] 题目描述 给定一个只包含数字的字符串,复原它并返回所有可能的 IP 地址格式. 示例: 输入: "25525511135" 输出: [&qu ...
- Java实现 LeetCode 93 复原IP地址
93. 复原IP地址 给定一个只包含数字的字符串,复原它并返回所有可能的 IP 地址格式. 示例: 输入: "25525511135" 输出: ["255.255.11. ...
- [LeetCode] Restore IP Addresses 复原IP地址
Given a string containing only digits, restore it by returning all possible valid IP address combina ...
- leetcode刷题-93复原IP地址
题目 给定一个只包含数字的字符串,复原它并返回所有可能的 IP 地址格式. 有效的 IP 地址正好由四个整数(每个整数位于 0 到 255 之间组成),整数之间用 '.' 分隔. 示例: 输入: &q ...
- LeetCode(93): 复原IP地址
Medium! 题目描述: 给定一个只包含数字的字符串,复原它并返回所有可能的 IP 地址格式. 示例: 输入: "25525511135" 输出: ["255.255. ...
- 93. 复原 IP 地址
做题思路or感想 这种字符串切割的问题都可以用回溯法来解决 递归三部曲: 递归参数 因为要切割字符串,所以要用一个startIndex来控制子串的开头位置,即是会切割出一个范围是[startIndex ...
- leetcode 93 复原IP地址
IP地址,分成四段,每段是0-255,按照每段的长度分别为1,2,3下一段长度分别1,2,3再下一段......进行递归遍历,能满足条件的假如res中.比较难想到的就是假如有一段是三位的010是不符合 ...
- 93复原IP地址。
from typing import List# 这道题不是很难,但是限制条件有很多.# 用递归的方法可以很容易的想到.只需要四层递归就好了.# 每次进行加上限制条件.过滤每一层就好了..class ...
- 复原IP地址
这道题有点不好理解 export default (str) => { // 保存所有符合条件的IP地址 let r = [] // 分四步递归处理ip分段 let search = (cur, ...
随机推荐
- 【链接】js监听input输入框内容变化
https://blog.csdn.net/idomyway/article/details/79078625 $("#input1").bind("input prop ...
- golang 中 map 转 struct
golang 中 map 转 struct package main import ( "fmt" "github.com/goinggo/mapstructure&qu ...
- 离线安装docker,并导入docker镜像
将docker离线安装包导入到系统中,解压并进入文件夹,使用下述命令进行安装: rpm -ivh *.rpm --nodeps --force 安装完成功使用,docker info 查看docker ...
- Linux下载安装mysql5.7教程
首先下载mysql 的安装包,可以去官网下载,网址:https://dev.mysql.com/downloads/mysql/ 然后下滑,在这个地方选择你想要安装的版本: 这里我选择的5.7.点击进 ...
- PAT甲级 进制转换题_C++题解
进制转换题 PAT (Advanced Level) Practice 进制转换题 目录 <算法笔记> 重点摘要 1015 Reversible Primes (20) 1019 Gene ...
- python学习-48 模块2
sys修改环境变量 ---------- 只能临时修改 import syssys.path.append() 例如: import sys sys.path.append('C:\Users\hua ...
- preg_replace
preg_replace — 执行一个正则表达式的搜索和替换 说明: preg_replace ( mixed $pattern , mixed $replacement , mixed $subje ...
- Scratch与物理·天文:模拟中国嫦娥探月工程,探索月球的背面!
北京时间2019年5月16日凌晨,国际顶级学术期刊<自然>(Nature)在线发表了一篇来自中国科学家的成果:中国的嫦娥四号月球探测器2019年1月3日在月球背面的冯卡门陨石坑(Von K ...
- adb链接时报错误10061解决方法
首先打开开发者选项然后依次操作: 1. 将安卓设备usb连接到电脑 2. 设备链接到wifi 3. Ping设备ip,检查是否可通信 4. 在cmd依次输入以下命令: 5. adb usb 6. ad ...
- android 和 js 交互
1.html代码 <script type="text/javascript"> function javacalljs(){ document.getElementB ...