Restore IP Addresses
題意:
Given a string containing only digits, restore it by returning all possible valid IP address combinations.
For example:
Given "25525511135",
return ["255.255.11.135", "255.255.111.35"]. (Order does not matter)
解題思路:
引用網友 愛做飯的小瑩子 的思路
"利用循環遞歸解決子問題。對於每個段內數來說,最多3位最少1位,所以在每一層可以循環3次,來嘗試填段。因為IP地址最多4個分段,當層數是3的時候說明已經嘗試填過3個段了,那麼把剩餘沒填的數段接到結尾即可。
這個過程中要保證的是填的數是合法的,最後拼接的剩餘的數也是合法的。
注意開頭如果是0的話要特殊處理,如果開頭是0,判斷整個串是不是0,不是的話該字符就是非法的。因為001,01都是不對的。"
其程式碼如下:
public class Solution {
List<String> res = new ArrayList<String>();
public List<String> restoreIpAddresses(String s) {
if (s == null || s.length() < 4 || s.length() > 12) {
return res;
}
helper(s, 0, new String());
return res;
}
//s表示剩下要處理的部份,temp表示已處理完的部份
private void helper(String s, int start, String temp) {
if (start == 3 && isValid(s)) {
res.add(temp + s);
return;
}
for (int i = 0; i < 3 && i < s.length() - 1; i++) {
String str = s.substring(0, i + 1);
if (isValid(str)) {
helper(s.substring(i + 1, s.length()), start + 1, temp + str + ".");
}
}
}
private boolean isValid(String s) {
//防止011這類的錯誤
if (s.charAt(0) == '0') {
return s.equals("0");
}
int val = Integer.parseInt(s);
if (val < 0 || val > 255) {
return false;
} else {
return true;
}
}
}
updated 2011.11.21
public class Solution {
public List<String> restoreIpAddresses(String s) {
List<String> res = new ArrayList<String>();
if (s == null || s.length() < 4 || s.length() > 12) {
return res;
}
helper(s, res, new ArrayList<String>());
return res;
}
private void helper(String s, List<String> res, List<String> tempRes) {
if (tempRes.size() == 4) {
if (s.length() == 0) {
String ip = genIP(tempRes);
if (!res.contains(ip)) {
res.add(ip);
}
}
return;
}
for (int i = 1; i <= Math.min(3, s.length()); i++) {
String ip = s.substring(0, i);
String remainString = s.substring(i, s.length());
if (isValid(ip)) {
tempRes.add(s.substring(0, i));
helper(remainString, res, tempRes);
tempRes.remove(tempRes.size() - 1);
}
}
}
private boolean isValid(String s) {
if (s.charAt(0) == '0') {
return s.equals("0");
}
int val = Integer.parseInt(s);
if (val >= 0 && val <=255) {
return true;
} else {
return false;
}
}
private String genIP(List<String> tempRes) {
StringBuilder sb = new StringBuilder();
for (int i = 0; i < 4; i++) {
if (i != 0) {
sb.append(".");
}
sb.append(tempRes.get(i));
}
return sb.toString();
}
}