public ArrayList<String> restoreIpAddresses(String s) { ArrayList<String> res = new ArrayList<String>(); if(s==null || s.length()==0) return res; helper(s,0,1,"",res); return res; } private void helper(String s, int index, int segment, String item, ArrayList<String> res) { if(index>=s.length()) return; if(segment == 4) { String str = s.substring(index); if(isValid(str)) { res.add(item+"."+str); } return; } for(int i=1;i<4&&(i+index<=s.length());i++) { String str = s.substring(index, index+i); if(isValid(str)) { if(segment==1) helper(s,index+i,segment+1,str,res); else helper(s,index+i,segment+1,item+"."+str,res); } } } private boolean isValid(String str) { if(str==null || str.length()>3) return false; int num = Integer.parseInt(str); if(str.charAt(0)==‘0‘ && str.length()>1) return false; if(num>=0 && num<=255) return true; return false; }实现中需要一个判断数字是否为合法ip地址的一项的函数,首先要在0-255之间,其次前面字符不能是0。剩下的就是NP问题的套路了,递归中套一个for循环,不熟悉的朋友可以看看N-Queens哈。
Restore IP Addresses -- LeetCode
原文地址:http://blog.csdn.net/linhuanmars/article/details/24683699