-
Notifications
You must be signed in to change notification settings - Fork 25
/
Copy pathP1_3.kt
29 lines (28 loc) · 1.24 KB
/
P1_3.kt
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
package ch06
class P1_3 {
fun isPalindrome(s: String): Boolean {
var start = 0
var end = s.length - 1
// 서로 중앙으로 이동해 나가다 겹치는 지점에 도달하면 종료
while (start < end) {
when {
// 영숫자인지 판별하고 유효하지 않으면 뒤로 한 칸 이동
!Character.isLetterOrDigit(s[start]) -> start++
// 영숫자인지 판별하고 유효하지 않으면 앞으로 한 칸 이동
!Character.isLetterOrDigit(s[end]) -> end--
else -> {
// 이 외에는 유효한 문자이므로 앞뒤 글자를 모두 소문자로 변경하여 비교
if (Character.toLowerCase(s[start]) != Character.toLowerCase(s[end])) {
// 하나라도 일치하지 않는다면 팰린드롬이 아니므로 false 리턴
return false
}
// 앞쪽 문자는 한 칸 뒤로, 뒤쪽 문자는 한 칸 앞으로 이동
start++
end--
}
}
}
// 무사히 종료될 경우 팰린드롬이므로 true 리턴
return true
}
}