코딩테스트

[문자열] 8. 유요한 팰린드롬

개발하는지호 2023. 12. 3. 13:06
8. 유효한 팰린드롬
 

설명

앞에서 읽을 때나 뒤에서 읽을 때나 같은 문자열을 팰린드롬이라고 합니다.

문자열이 입력되면 해당 문자열이 팰린드롬이면 "YES", 아니면 “NO"를 출력하는 프로그램을 작성하세요.

단 회문을 검사할 때 알파벳만 가지고 회문을 검사하며, 대소문자를 구분하지 않습니다.

알파벳 이외의 문자들의 무시합니다.

입력

첫 줄에 길이 100을 넘지 않는 공백이 없는 문자열이 주어집니다.

출력

첫 번째 줄에 팰린드롬인지의 결과를 YES 또는 NO로 출력합니다.

예시 입력 1 

found7, time: study; Yduts; emit, 7Dnuof

예시 출력 1

YES

 

 

<<풀이>>

 

이 문제는 정규화 표현과 replaceAll 메소드를 사용한다.

 

import java.util.Scanner;

class Main {

    public String solution(String s){
        String answer = "NO";
        s = s.toUpperCase().replaceAll("[^A-Z]", "");
        String tmp = new StringBuilder(s).reverse().toString();
        if(s.equals(tmp)) answer = "YES";

        return answer;
    }

    public static void main(String[] args) {
        Main T = new Main();
        Scanner in = new Scanner(System.in);
        String str = in.nextLine();
        System.out.print(T.solution(str));
    }
}

 

여기서 replace 메서드는 사용하지 못하지만 replaceAll은 정규식 표현을 사용할 수 있다.

 

^ : 부정

[A-Z] : A 부터 Z 까지

 

즉, [^A-Z] 는 A부터 Z까지 아니면 "" 해라 라는 표현이다 *띄어쓰기도 문자로 포함한다!

 

정규식 표현에 대해서 개별적으로 정리가 필요하다.!