728x90
나의 풀이법.
아쉽게도 코드 실행 부분에서는 통과가 되었으나. 제출 후 채점에서는 시간초과로.. + 실패 2개 로 틀렸다.
실패 이유 아시는 분 댓글 달아주시면 감사하겠습니다.
private fun solution(ingredient: IntArray): Int {
var answer: Int = 0
val a = ArrayList<String>()
for (i in ingredient) {
a.add(i.toString())
if (a.size > 4) {
val b = a.joinToString("")
if (b.substring(a.size - 4 until a.size) == "1231") {
a.dropLast(4)
answer++
}
}
}
return answer
}
다른 분들의 풀이
첫 번째 풀이 법.
private fun solution2(ingredient: IntArray): Int {
var answer: Int = 0
val sb = StringBuilder()
for (item in ingredient) {
sb.append('0' + item)
if (sb.length >= 4 && sb.substring(sb.length - 4) == "1231") {
sb.setLength(sb.length - 4)
answer++
}
}
return answer
}
StringBuilder() 를 사용하여 풀었다. 내 것과 비슷해 보이긴하나 속도면에서 큰 차이가 있었고 실패도 없었다.
private fun solution3(ingredient: IntArray): Int {
var answer: Int = 0
val a = Stack<Int>()
for (i in ingredient) {
a.add(i)
if (a.peek() == 1 && a.size >= 4) {
val first = a[a.size - 4] == 1
val second = a[a.size - 3] == 2
val third = a[a.size - 2] == 3
val fourth = a[a.size - 1] == 1
if (first && second && third && fourth) {
repeat(4) { a.pop() }
answer++
}
}
}
return answer
}
Stack<>() 을 사용하여 풀으셨는데 내 생각엔 위의 것 보다 조금 더 간단해 보인다.
'알고리즘' 카테고리의 다른 글
[코딩 테스트] Level. 1 과일장수 (kotlin,코틀린) (0) | 2023.05.18 |
---|---|
[코딩 테스트] Level. 1 푸드파이터 개최 (0) | 2023.05.17 |
[코딩 테스트] Level. 1 옹알이 (kotlin,코틀린) (1) | 2023.05.16 |
[코딩테스트] Level. 1 숫자 짝꿍 (kotlin,코틀린) (0) | 2023.04.22 |
[코딩테스트] Level. 1 내적 Kotlin (0) | 2023.03.28 |