lintcode:恢复IP地址
恢复IP地址
给一个由数字组成的字符串。求出其可能恢复为的所有IP地址。
给出字符串 "25525511135",所有可能的IP地址为:
[
"255.255.11.135",
"255.255.111.35"
]
(顺序无关紧要)
解题
深度优先遍历
注意:
1.中间IP位置不能以0开始,0.01.01.1非法,应该是0.0.101.1或者0.0.10.11
2.数不能大于255
public class Solution {
/**
* @param s the IP string
* @return All possible valid IP addresses
* 不能包括01 001这样的格式
*/
public ArrayList<String> restoreIpAddresses(String s) {
// Write your code here
ArrayList<String> list = new ArrayList<String>();
String IP="";
int start = 0;
int IPsize = 0;
dfs(list,IP,s,start,IPsize);
return list;
}
public void dfs(ArrayList<String> list,String IP,String s,int start,int IPsize){
if(start == s.length()||IPsize>=4)
return;
if(IPsize == 3){
String subIP = s.substring(start);
if(isStartZero(subIP))
return;
if(!isLegal(subIP))
return;
IP+="." + subIP;
if(!list.contains(IP))
list.add(IP);
return;
}else{
for(int i = start;i<s.length();i++){
int j = 1;
while(start+j<s.length() && j<=4){
String subIP = s.substring(start,start+j);
if(isStartZero(subIP))
break;
if(!isLegal(subIP))
break;
if(IPsize == 0){
IP+=subIP;
IPsize++;
dfs(list,IP,s,start+j,IPsize);
IP = "";
}else{
IP+="." + subIP;
IPsize++;
dfs(list,IP,s,start+j,IPsize);
IP = IP.substring(0,IP.length() - j-1);
}
IPsize--;
j++;
}
}
}
}
public boolean isLegal(String subIP){
Long numIP = Long.valueOf(subIP);
if(numIP< 0 || numIP>255)
return false;
return true;
}
public boolean isStartZero(String subIP){
if(subIP.substring(0,1).equals("0") && subIP.length() >=2)
return true;
return false;
}
}
lintcode:恢复IP地址的更多相关文章
- lintcode - 恢复ip地址
class Solution { public: /* * @param s: the IP string * @return: All possible valid IP addresses */ ...
- lintcode-【中等】恢复IP地址
题目 给一个由数字组成的字符串.求出其可能恢复为的所有IP地址.链接. 样例 给出字符串 "25525511135",所有可能的IP地址为: [ "255.255.11. ...
- 恢复所有情况的ip地址
在终端下输入一串ip字符串如:19219219211,ip地址可能是19.219.219.211.192.19.219.211.192.192.19.211和192.192.192.11. 以下是本人 ...
- Linux网络管理1---(Linux配置IP地址,ifconfig、配置文件)
1.Linux配置IP 地址 ifconfig命令临时配置IP 地址 ifconfig命令,最常用的功能是查看本机的网络的配置状态(当然也可以配置网络,不过是暂时性的),直接输入ifconfig命令就 ...
- 【linux】虚拟机安装centos后ping ip地址出现错误:Network is unreachable
来源:https://my.oschina.net/stonezing/blog/515480 方案一: 进入/etc/sysconfig/network-scripts/ 查看这下面的文件 每个人的 ...
- IP地址更改小工具(bat命令)
为了方便切换IP地址,特编制bat命令代码来实现,将以下代码复制到txt文本中,然后保存为bat文件,双击bat文件运行即可. 通过bat命令运行,自动修改IP地址,代码如下: @echo off c ...
- IP地址漂移的实现与原理
当前备份软件比较流行,其中用到的关键技术是IP 地址漂移, 实际上IP地址漂移技术是利用共享的“虚拟”IP地址,当本地进行节点切换与路由切换,使另一端的发送和收方端没有感觉到本地节点地址有变化,保证了 ...
- 转:数据包经由路由转发时源、目的IP地址及MAC地址变化情况
数据包经由路由转发时源.目的IP地址及MAC地址变化情况. IP数据包经由路由转发的时候源ip,目的ip,源MAC,目的mac是否发生改变,如何改变? A—–(B1-B2)—–(C1-C2)—— ...
- openstack私有云布署实践【19 通过python客户端 创建实例VM指定IP地址】
还有一种创建方式 是使用py开发工具,调用openstackclient的方法进行创建实例 ,好处就是可随意指定我们要的虚拟机IP地址,需求的场景就是,某天我们需要主动分配一个比较熟知的IP用作某个服 ...
随机推荐
- Swift弹窗
在一个ViewController中使用以下代码: let alertController = UIAlertController(title: "Game Set", messa ...
- ultraedit高亮显示设置
ultraedit高亮显示设置 | 浏览:2333 | 更新:2014-02-20 23:05 1 2 3 4 5 6 7 分步阅读 百度经验:jingyan.baidu.com 写代码的人对ultr ...
- 四则运算程序扩展:将程序改为java语言,并允许用户输入,对输入结果进行验证
题目 每个同学选一个方向,把程序扩展一下:1.让程序能接受用户输入答案,并判定对错.最后给出总共对/错 的数量.2.把程序变成一个网页程序,用户通过设定参数,就可以得到各种题目.3.把程序变成一个Wi ...
- Window 添加定时任务
简单任务 右键点击 我的电脑->管理->任务计划程序库->创建基本任务 然后选择任务类型,触发时间,触发程序就可以了,可以精确到秒 带参数的计划任务 如果执行程序是cmd 可选参数那 ...
- html5 drag api详解
可以夸张点说,如果你不会拖拽,你不是一个合格的前端开发. 回想下,以前我们是怎么实现拖拽的,主要有以下几步: 1.目标元素绑定mousedown事件,记录下此时鼠标位置和拖拽元素的位置差,分别是 di ...
- IE6中布局常见问题
1.众所周知,每个IE的版本都有两种模式,怪异模式(混杂模式)和标准模式.下图附上针对IE的hack. 2.另外有一种引进css的方法,也可以作为调整网站hack的方法:<!—[if IE 6] ...
- 【Python】可变对象和不可变对象
Python在heap中分配的对象分成两类:可变对象和不可变对象.所谓可变对象是指,对象的内容是可变的,例如list.而不可变的对象则相反,表示其内容不可变. 不可变对象:int,string,flo ...
- 【CentOs】开机启动与防火墙
说明: 开机启动使用的命令式chkconfig .防火墙相关的命令式iptables 1.chkconfig 2.iptables 1.chkconfig 参数: --add 新增所指定的系统服务 ...
- hdu 1301 Jungle Roads 最小生成树
题目链接:http://acm.hdu.edu.cn/showproblem.php?pid=1301 The Head Elder of the tropical island of Lagrish ...
- idea maven添加jar包
在“项目结构“里设置 选择libaray,添加jar包