본문 바로가기
알고리즘 문제

leetcode easy 9. Palindrome Number 정답과 풀이

by 비타민찌 2026. 1. 7.
728x90
문제

 

Given an integer x, return true if x is a palindrome, and false otherwise.


Example 1:

Input: x = 121
Output: true
Explanation: 121 reads as 121 from left to right and from right to left.

 

Example 2:

Input: x = -121
Output: false
Explanation: From left to right, it reads -121. From right to left, it becomes 121-. Therefore it is not a palindrome.

 

Example 3:

Input: x = 10
Output: false
Explanation: Reads 01 from right to left. Therefore it is not a palindrome.

 

 

문제 힌트는 '뒤쪽 절반을 뒤집은 값'인 reversed 였다.

 

 

정답
class Solution {
    public boolean isPalindrome(int x) {
        // 음수이거나 끝자리가 0인데 0이 아닌 경우
        if (x < 0 || (x % 10 == 0 && x != 0)) {
            return false;
        }

        int reversed = 0;

        while (x > reversed) {
            int digit = x % 10;
            reversed = reversed * 10 + digit;
            x /= 10;
        }

        // 짝수 자리 or 홀수 자리
        return x == reversed || x == reversed / 10;
    }
}

 

 

먼저 초기 상태는 이렇다.

x = 1221, reversed = 0.

여기서 뒤쪽 절반을 뒤집은 값을 만들어보자.

 

1) digit = x % 10; 으로 x의 맨 뒤 숫자 하나를 뗀다.

2) reversed = reversed * 10 + digit; 으로 뒤집은 숫자에 붙인다.

3) x = x / 10; 으로 x의 맨 뒤 숫자 제거.

 

reversed = 1, x = 122 

reversed = 12, x = 12

 

이런 식으로 되고, 이것을  

x > reversed 일때만 동작하게 하면 된다.

 

 

그리고 이렇게 짝수인 경우, 

12 == 12 로 x == reversed 성립되지만 

 

12321 같은 홀수라면

x = 12, reversed = 123 이 된 시점에서 

반복이 끝난다. (x > reversed)

 

12 | 3 | 21
↑        ↑
앞        뒤

 

여기서 가운데 3은 비교 대상이 아니다. 

그래서 reversed / 10으로 가운데 숫자를 제거한다.

 

reversed / 10 = 12

   (123)

 

그래서 OR 조건으로 return 해준다.

 

return
    x == reversed          // 짝수 자리 수
    || 
    x == reversed / 10;    // 홀수 자리 수

 

 

 

시행착오

 

easy 인데도 처음에 갈피를 좀 못잡았다.

x를 x길이의 배열에 넣고 비교해야하나 고민 했는데

이건 int → String → char 배열 변환이 필수적이라 

영 아닌것 같다는 생각을 했다.

이 방식으로 풀었다면 이렇게 됐을 것이다.

 

class Solution {
    public boolean isPalindrome(int x) {
        String s = String.valueOf(x);
        int left = 0, right = s.length() - 1;

        while (left < right) {
            if (s.charAt(left) != s.charAt(right)) {
                return false;
            }
            left++;
            right--;
        }
        return true;
    }
}

 

 

String.valueOf(x); 로 x 길이를 구하고

왼쪽 오른쪽을 정해서 비교해 나가는 방식이다.

 

이렇게 풀면 다음과 같은 점수를 받는다. 

 

728x90

'알고리즘 문제' 카테고리의 다른 글

Leetcode14 Longest Common Prefix  (0) 2026.01.07
Leetcode 13. Roman to Integer  (0) 2026.01.07
2022 네이버 Track 인턴쉽 코딩테스트  (0) 2022.06.20

댓글