알고리즘 문제 풀이/프로그래머스
[Algorithm] 프로그래머스 - 문자열 밀기 (Kotlin)
참깨빵위에참깨빵_
2023. 2. 1. 04:07
728x90
반응형
문자열 hello에서 각 문자를 오른쪽으로 한 칸씩 밀고 마지막 문자는 맨 앞으로 이동시키면 ohell이 된다. 이걸 문자열을 민다고 정의한다면 문자열 A, B가 매개변수로 주어질 때, A를 밀어서 B가 될 수 있다면 밀어야 하는 최소 횟수를 리턴하고 밀어서 B가 될 수 없으면 -1을 리턴하는 solution()을 완성하라
문자열 길이만큼 rotate()를 써보거나 다른 방법을 써봤지만 풀리지 않아서 다른 사람의 풀이를 참고해 코틀린으로 바꿨다.
문자열 밀기 - Java [프로그래머스 입문]
❤️ Problem 더보기 문제 문자열 "hello"에서 각 문자를 오른쪽으로 한 칸씩 밀고 마지막 문자는 맨 앞으로 이동시키면 "ohell"이 됩니다. 이것을 문자열을 민다고 정의한다면 문자열 A와 B가 매개변
gyulpiki.tistory.com
class Solution {
fun solution(A: String, B: String): Int {
var A = A
var answer = 0
while (A != B) {
answer++
val sb = StringBuilder(A)
val tmp = sb.substring(sb.length - 1)
sb.insert(0, tmp)
sb.deleteCharAt(sb.length - 1)
A = sb.toString()
if (answer > A.length) {
answer = -1
break
} else {
continue
}
}
return answer
}
}
간단하게 풀면 이렇게 된다는데 어떻게 이게 되는지는 이해가 잘 안 된다.
class Solution {
fun solution(A: String, B: String): Int = (B + B).indexOf(A)
}
반응형