将字符串划分成ip地址,需要注意几点:
1、ip地址由四个整数组成;
2、每个整数的范围是[0,255];
3、四个整数通过逗号分隔符连接
4、每个整数除了它本身是0的情况之外,不能以0开头
我主要采用深度优先搜索+回溯的方法解决

对每一部分的整数的处理方式都是一样的,先取一位数,然后添加到临时要划分的ip字符串中,继续递归进行后面整数的划分,递归的过程中,如果划分出四个整数同时字符串又使用完毕,则组成了一种ip,否则就不是,直接返回。

    public ArrayList<String> restoreIpAddresses (String s) {
        // write code here
        if (s == null || s.length() <= 3 || s.length() > 12){
            return new ArrayList<>();
        }
        ArrayList<String> list = new ArrayList<>();
        backTrace(0,s,list,new StringBuilder());

        return list;
    }


    private void backTrace(int partNum, String s, List<String> list,StringBuilder midIp){

        if (partNum == 4 || s.length() == 0){

            if (partNum == 4 && s.length() == 0){
                list.add(midIp.toString());

            }
            return;
        }

        for (int i = 0; i <= 2 && i < s.length(); i++) {

            if (i != 0 && s.charAt(0) == '0'){
                break;
            }

            String substring = s.substring(0, i + 1);

            if (Integer.valueOf(substring) <= 255){

                if (midIp.length() != 0){
                    substring = "." + substring;
                }

                midIp.append(substring);
                backTrace(partNum+1,s.substring(i+1),list,midIp);
                midIp.delete(midIp.length() - substring.length(),midIp.length());
            }
        }

    }