93. Restore IP Addresses

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)

Solution

public class Solution {
   public List<String> restoreIpAddresses(String s) {
        List<String> result = new ArrayList<>();

        if (s.length() >= 13) {
            return new ArrayList<>();    
        }

        helper(4, 0, s, "", result);
        return result;
    }

    public void helper(int numberOfDots, int start, String originalString, String currentSolution, List<String> result) {
        if (numberOfDots == 0 && start >= originalString.length()) {
            result.add(currentSolution);
            return;
        }

        for (int i = 1; i < 4; i++) {
            int end = start + i;
            if (end <= originalString.length()) {
                String temp = originalString.substring(start, end);
                Integer integer = Integer.valueOf(temp);
                if (String.valueOf(integer).length() != temp.length()) {
                    return;
                }
                if (integer >= 0 && integer <= 255) {
                    helper(numberOfDots - 1, end, originalString, currentSolution.equals("") ? originalString.substring(start, end) : currentSolution + "." + originalString.substring(start, end), result);
                }

            }
        }

    }

}

Last updated