前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >Java实现解析IP地址的方法,给出一串数字,生成正确的IP地址

Java实现解析IP地址的方法,给出一串数字,生成正确的IP地址

作者头像
用户1289394
发布2018-02-27 15:38:19
1.9K0
发布2018-02-27 15:38:19
举报
文章被收录于专栏:Java学习网Java学习网Java学习网

给定一个只包含数字的字符串,通过方法返回所有可能的有效的IP地址组合。

例如:给出“25525511135”,返回(“255.255.11.135”、“255.255.111.35”)。

网络配图

Java解决方法:

这是一个典型的搜索问题,它可以通过使用DFS解决。

代码如下:

import java.util.ArrayList;
import java.util.List;
public class TestIP {
//Java实现解析IP地址的方法,给出一串数字,通过方法生成正确的IP地址
public List<String> restoreIpAddresses(String s) {
ArrayList<ArrayList<String>> result = new ArrayList<ArrayList<String>>();
ArrayList<String> t = new ArrayList<String>();
dfs(result, s, 0, t);
ArrayList<String> finalResult = new ArrayList<String>();
for(ArrayList<String> l: result){
StringBuilder sb = new StringBuilder();
for(String str: l){
sb.append(str+".");
}
sb.setLength(sb.length() - 1);
finalResult.add(sb.toString());
}
return finalResult;
}
public void dfs(ArrayList<ArrayList<String>> result, String s, int start, ArrayList<String> t){
//if already get 4 numbers, but s is not consumed, return
if(t.size()>=4 && start!=s.length())
return;
//make sure t's size + remaining string's length >=4
if((t.size()+s.length()-start+1)<4)
return;
//t's size is 4 and no remaining part that is not consumed.
if(t.size()==4 && start==s.length()){
ArrayList<String> temp = new ArrayList<String>(t);
result.add(temp);
return;
}
for(int i=1; i<=3; i++){
//make sure the index is within the boundary
if(start+i>s.length())
break;
String sub = s.substring(start, start+i);
//handle case like 001. i.e., if length > 1 and first char is 0, ignore the case.
if(i>1 && s.charAt(start)=='0'){
break;
}
//make sure each number <= 255
if(Integer.valueOf(sub)>255)
break;
t.add(sub);
dfs(result, s, start+i, t);
t.remove(t.size()-1);
}
}
}
本文参与 腾讯云自媒体分享计划,分享自微信公众号。
原始发表:2018-01-04,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 Java学习网 微信公众号,前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体分享计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档