第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, ...
随机推荐
- [转帖]nginx location配置详细解释
nginx location配置详细解释 http://outofmemory.cn/code-snippet/742/nginx-location-configuration-xiangxi-exp ...
- python 脚本bak文件还原mssql数据库
# -*- coding=utf-8 -*- import pyodbc from datetime import datetime import pymssql import decimal cla ...
- oracle经典查询语句
1. select * from emp; 2. select empno, ename, job from emp; 3. select empno 编号, ename 姓名, job 工作 ...
- Windows 下redis的安装和使用
1.下载 Window 下载地址:https://github.com/MSOpenTech/redis/releases 查找版本对应的一个MSI或者zip文件下载 2.安装 MSI文件需要安装 z ...
- Django之Form与ModelForm组件
Django之Form与ModelForm组件 1.Form介绍 Form组件的主要功能如下: 生成页面可用的HTML标签 对用户提交的数据进行校验 O 保留上次的输入内容 普通方式手写注册功能 vi ...
- 1269: 划分数(Java)
WUSTOJ 1269: 划分数 参考博客 果7的博客 题目 将 1 个数 n 分成 m 份,求划分的种数.更多内容点击标题. 分析 唯一需要注意的地方是不考虑顺序.其他的直接看代码即可. 代 ...
- Warning: popen() has been disabled for security reasons in OS/Guess.php on line 241
今天使用pecl install swoole命令编译安装swoole的时候提示:Warning: popen() has been disabled for security reasons in ...
- Centos7.3 为php7 安装swoole 扩展
今天心血来潮想在服务器上安装一下swoole扩展 下面列一下教程: xshell进入你的服务器 然后目录自选吧 反正我放在根目录了 下面是扩展链接: wget https://github.co ...
- (二)Redis之Jedis概念和HelloWorld实现以及JedisPool的使用
一.Jedis概念 实际开发中,我们需要用Redis的连接工具连接Redis然后操作Redis, 对于主流语言,Redis都提供了对应的客户端: 官网:https://redis.io/clients ...
- Spring Boot 默认首页
//继承 WebMvcConfigurerAdapter @Override public void addViewControllers(ViewControllerRegistry registr ...