이 알고리즘 문제는 인프런의 자바(Java) 알고리즘 문제풀이 입문: 코딩테스트 대비 (김태원)의 문제입니다.
문제 설명
코드
import java.io.BufferedReader;
import java.io.IOException;
import java.io.InputStreamReader;
public class sec01_08 {
public static String solution(String str) {
int lp = 0; int rp = str.length() - 1;
String lower = str.toLowerCase();
while (lp < rp) {
// 왼쪽 포인터가 가리키는 문자가 알파벳이나 숫자가 아닐 때 포인터 이동
while (lp < rp && !Character.isLetterOrDigit(lower.charAt(lp))) lp++;
// 오른쪽 포인터가 가리키는 문자가 알파벳이나 숫자가 아닐 때 포인터 이동
while (lp < rp && !Character.isLetterOrDigit(lower.charAt(rp))) rp--;
// 양 끝 문자가 다르면 회문이 아님
if (lower.charAt(lp) != lower.charAt(rp)) return "NO";
// 양 끝 문자가 같으면 포인터 이동
lp++;
rp--;
}
return "YES";
}
public static void main(String[] args) throws IOException {
BufferedReader br = new BufferedReader(new InputStreamReader(System.in));
System.out.println(solution(br.readLine()));
}
}
설명
- 코드 주석 참고
'자료구조 & 알고리즘 > Inflearn' 카테고리의 다른 글
[인프런 알고리즘] Chapter 1, 10번 문제(가장 짧은 문자거리) (0) | 2024.07.09 |
---|---|
[인프런 알고리즘] Chapter 1, 9번 문제(숫자만 추출) (0) | 2024.07.08 |
[인프런 알고리즘] Chapter 1, 7번 문제(회문 문자열) (0) | 2024.07.07 |
[인프런 알고리즘] Chapter 1, 6번 문제(중복 문자 제거) (0) | 2024.07.07 |
[인프런 알고리즘] Chpater 1, 5번 문제(특정 문자 뒤집기) (0) | 2024.07.06 |