문제
설명
앞에서 읽을 때나 뒤에서 읽을 때나 같은 문자열을 팰린드롬이라고 합니다.
문자열이 입력되면 해당 문자열이 팰린드롬이면 "YES", 아니면 “NO"를 출력하는 프로그램을 작성하세요.
단 회문을 검사할 때 알파벳만 가지고 회문을 검사하며, 대소문자를 구분하지 않습니다.
알파벳 이외의 문자들의 무시합니다.
입력
첫 줄에 길이 100을 넘지 않는 공백이 없는 문자열이 주어집니다.
출력
첫 번째 줄에 팰린드롬인지의 결과를 YES 또는 NO로 출력합니다.
코드
import java.util.Scanner;
public class Main1_8 {
public String Solution(String s) {
String answer = "NO";
s = s.toUpperCase().replaceAll("[^A-Z]", ""); // 특수문자 제거
// replace는 정규식 X, replaceAll은 정규식 O
// System.out.println(s);
String revStr = new StringBuilder(s).reverse().toString();
if(revStr.equals(s)) answer = "YES";
return answer;
}
public static void main(String[] args) {
Main1_8 T = new Main1_8();
Scanner sc = new Scanner(System.in);
String str = sc.nextLine();
System.out.println(T.Solution(str));
}
}
결과
알게된 점
1. replace()와 replaceAll()
https://rookie-programmer.tistory.com/21
'Algorithm > Inflearn' 카테고리의 다른 글
[Inflearn] 자바 알고리즘 문제풀이 #01-10 10. 가장 짧은 문자거리 (0) | 2022.11.02 |
---|---|
[Inflearn] 자바 알고리즘 문제풀이 #01-09 9. 숫자만 추출 (0) | 2022.11.01 |
[Inflearn] 자바 알고리즘 문제풀이 #01-07 7. 회문 문자열 (0) | 2022.10.27 |
[Inflearn] 자바 알고리즘 문제풀이 #01-06 6. 중복문자제거 (0) | 2022.10.26 |
[Inflearn] 자바 알고리즘 문제풀이 #01-05 5. 특정 문자 뒤집기 (0) | 2022.10.25 |