[인프런 알고리즘] Chapter 1, 7번 문제(회문 문자열)자료구조 & 알고리즘/Inflearn2024. 7. 7. 07:08
Table of Contents
이 알고리즘 문제는 인프런의 자바(Java) 알고리즘 문제풀이 입문: 코딩테스트 대비 (김태원)의 문제입니다.
문제 설명
코드
import java.io.BufferedReader;
import java.io.IOException;
import java.io.InputStreamReader;
public class sec01_07 {
public static String solution(String str) {
int lp = 0; int rp = str.length() -1;
String lower = str.toLowerCase();
char[] temp = lower.toCharArray();
while (lp < rp){
if(temp[lp] != temp[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()));
}
}
설명
- solution 메서드는 문자열 str을 입력받아 회문인지 여부를 판단하여 "YES" 또는 "NO"를 반환한다.
- int lp = 0; int rp = str.length() - 1;: lp는 왼쪽 포인터, rp는 오른쪽 포인터를 의미한다. lp는 문자열의 시작에서, rp는 문자열의 끝에서 시작한다.
- String lower = str.toLowerCase();: 대소문자를 구분하지 않기 위해 문자열을 모두 소문자로 변환한다.
- char[] temp = lower.toCharArray();: 소문자로 변환된 문자열을 문자 배열로 변환한다.
while (lp < rp): 왼쪽 포인터가 오른쪽 포인터보다 작을 동안 반복한다.
if (temp[lp] != temp[rp]): 양 끝의 문자가 다르면 회문이 아니므로 "NO"를 반환한다.
++lp; --rp;: 왼쪽 포인터는 오른쪽으로, 오른쪽 포인터는 왼쪽으로 이동한다. - 모든 문자가 일치하면 "YES"를 반환한다.
'자료구조 & 알고리즘 > Inflearn' 카테고리의 다른 글
[인프런 알고리즘] Chapter 1, 9번 문제(숫자만 추출) (0) | 2024.07.08 |
---|---|
[인프런 알고리즘] Chapter 1, 8번 문제(유효한 팰린드롬) (0) | 2024.07.07 |
[인프런 알고리즘] Chapter 1, 6번 문제(중복 문자 제거) (0) | 2024.07.07 |
[인프런 알고리즘] Chpater 1, 5번 문제(특정 문자 뒤집기) (0) | 2024.07.06 |
[인프런 알고리즘] Chapter 1, 4번 문제(단어 뒤집기) (0) | 2024.07.05 |