博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
93. Restore IP Addresses (DFS, String)
阅读量:4073 次
发布时间:2019-05-25

本文共 1025 字,大约阅读时间需要 3 分钟。

Given a string containing only digits, restore it by returning all possible valid IP address combinations.

Example:

Input: "25525511135"Output: ["255.255.11.135", "255.255.111.35"]

思路:

合法性的规则:

IP 地址的规律是分4个Part,每个Part是从0-255的数字

0-255的数字,转换成字符,即每个Part 可能由一个字符组成,二个字符组成,或者是三个字符组成。

写一个For循环每一层从1个字符开始取一直到3个字符,再加一个isValid的函数来验证取的字符是否是合法数字,如果是合法的数字,我们再进行下一层递归,否则跳过。

注意:

1. isValid函数边界:有0开头的字符串只有“0”合法

2. 循环判定条件还包括长度

3. 每次判定合法性之后加上substr和“.”

4. 最后只有用完所有字符并且有四个部分才是争取的ip。此时直接验证剩下字符的合法性即可(合法性就保证位数不大于3)

public List
restoreIpAddresses(String s) { List
res = new ArrayList
(); if(s.length()==0 || s.equals("") ||s.length()>12) return res; dfs(s,0,"",res); return res; } private void dfs(String s,int part, String tmp,List
res){ if(part==3 && isValid(s)){ res.add(tmp+s); return; } for(int i=1;i<4 && i
=0 && value<=255) return true; else return false; }

 

转载地址:http://cnfni.baihongyu.com/

你可能感兴趣的文章
C++ STL标准库与泛型编程(四)Deque、Queue、Stack 深度探索
查看>>
C++ STL标准库 算法
查看>>
JVM内存模型_Minor GC笔记
查看>>
SpringCloud学习之PassCloud——(一)PassCloud源代码下载
查看>>
SpringCloud学习之PassCloud——(二)passcloud-master源代码部署
查看>>
SpringCloud学习之PassCloud——(三)passcloud-master各模块、paascloud-mall-web、paascloud-login-web启动
查看>>
利用NLP进行情感分析,建立模型并使用Java调用
查看>>
Linux下安装Python环境并部署NLP项目
查看>>
Nginx篇-springCloud配置Gateway+Nginx进行反向代理和负载均衡
查看>>
Nginx篇-Nginx配置动静分离
查看>>
缓存篇-Redis缓存失效以及解决方案
查看>>
缓存篇-使用Redis进行分布式锁应用
查看>>
缓存篇-Redisson的使用
查看>>
phpquery抓取网站内容简单介绍
查看>>
科技助力,医疗AI让病症“无处遁形”
查看>>
AI人才大战硝烟袅袅,缺口该如何填补?
查看>>
如何有效降低APP的崩溃率?
查看>>
开源的意义是什么?盘点当前五大优质开源项目
查看>>
5G商用牌照正式发放!万亿级市场大门开启
查看>>
5G时代来临 哪些AI应用将快速落地?
查看>>