알고리즘
[leetcode] 125. Valid Palindrome
Night-Owl
2021. 6. 22. 02:31
반응형
문제
풀이
주어진 문자열이 팰린드롬인지 확인하는 문제이다.
- 팰린드롬은 뒤집어도 같은 말이 되는 단어 또는 문장을 말한다.
문제에서 팰린드롬인지 확인할 때 알파벳과 숫자만을 대상으로 하고 대소문자를 구분하지 않는다고 했다.
우선 주어진 문자열을 다 소문자로 바꾼다.
그리고 정규식으로 알파벳과 숫자가 아닌 불필요한 문자를 제거한다.
이제 for 문을 돌면서 왼쪽 인덱스의 값과 오른쪽 인덱스의 값이 같은지를 확인한다.
왼쪽은 한 칸씩 오른쪽으로, 오른쪽은 한 칸씩 왼쪽으로 이동하면서 비교한다.
만약 비교한 값이 다르면 팰린드롬이 아니고 모두 같으면 팰린드롬이다.
코드
class Solution {
public boolean isPalindrome(String s) {
s = s.toLowerCase();
String alphanumericInput = s.replaceAll("[^A-Za-z0-9]", "");
char[] targets = alphanumericInput.toCharArray();
int left = 0;
int right = targets.length-1;
for(int idx=0; idx < targets.length/2; idx++){
if(targets[left++] != targets[right--]){
return false;
}
}
return true;
}
}
제출하고 확인해보니깐 작년에 Go언어로 제출한 풀이가 존재했다.
확인해보니깐 역시 똑같은 방법으로 풀었었다.
사람 쉽게 안 변하는 것 같다.
func isPalindrome(s string) bool {
reg, err := regexp.Compile("[^a-zA-Z0-9]+")
if err != nil {
log.Fatal(err)
}
processedString := strings.ToLower(reg.ReplaceAllString(s, ""))
maxIdx := len(processedString) - 1
for idx := 0; idx <= maxIdx; idx++ {
if processedString[idx] != processedString[maxIdx-idx] {
return false
}
}
return true
}
참고
반응형