| 
 | 1 | +class Solution {  | 
 | 2 | +    public int largestPalindrome(int n) {  | 
 | 3 | +        // https://leetcode.com/problems/largest-palindrome-product/discuss/96297/Java-Solution-using-assumed-max-palindrom  | 
 | 4 | +        // if input is 1 then max is 9   | 
 | 5 | +        if(n == 1){  | 
 | 6 | +            return 9;  | 
 | 7 | +        }  | 
 | 8 | +          | 
 | 9 | +        // if n = 3 then upperBound = 999 and lowerBound = 99  | 
 | 10 | +        int upperBound = (int) Math.pow(10, n) - 1, lowerBound = upperBound / 10;  | 
 | 11 | +        long maxNumber = (long) upperBound * (long) upperBound;  | 
 | 12 | +          | 
 | 13 | +        // represents the first half of the maximum assumed palindrom.  | 
 | 14 | +        // e.g. if n = 3 then maxNumber = 999 x 999 = 998001 so firstHalf = 998  | 
 | 15 | +        int firstHalf = (int)(maxNumber / (long) Math.pow(10, n));  | 
 | 16 | +          | 
 | 17 | +        boolean palindromFound = false;  | 
 | 18 | +        long palindrom = 0;  | 
 | 19 | +          | 
 | 20 | +        while (!palindromFound) {  | 
 | 21 | +            // creates maximum assumed palindrom  | 
 | 22 | +            // e.g. if n = 3 first time the maximum assumed palindrom will be 998 899  | 
 | 23 | +            palindrom = createPalindrom(firstHalf);  | 
 | 24 | +              | 
 | 25 | +            // here i and palindrom/i forms the two factor of assumed palindrom  | 
 | 26 | +            for (long i = upperBound; upperBound > lowerBound; i--) {  | 
 | 27 | +                // if n= 3 none of the factor of palindrom  can be more than 999 or less than square root of assumed palindrom   | 
 | 28 | +                if (palindrom / i > maxNumber || i * i < palindrom) {  | 
 | 29 | +                    break;  | 
 | 30 | +                }  | 
 | 31 | +                  | 
 | 32 | +                // if two factors found, where both of them are n-digits,  | 
 | 33 | +                if (palindrom % i == 0) {  | 
 | 34 | +                    palindromFound = true;  | 
 | 35 | +                    break;  | 
 | 36 | +                }  | 
 | 37 | +            }  | 
 | 38 | + | 
 | 39 | +            firstHalf--;  | 
 | 40 | +        }  | 
 | 41 | + | 
 | 42 | +        return (int) (palindrom % 1337);  | 
 | 43 | +    }  | 
 | 44 | + | 
 | 45 | +    private long createPalindrom(long num) {  | 
 | 46 | +        String str = num + new StringBuilder().append(num).reverse().toString();  | 
 | 47 | +        return Long.parseLong(str);  | 
 | 48 | +    }  | 
 | 49 | +}  | 
0 commit comments