코딩테스트

프로그래머스 x만큼 간격이 n개의 숫자

다시은 2023. 12. 14. 10:14

class Solution {
    fun solution(x: Int, n: Int): mutableListOf<Int> {
        var answer = mutableListOf<Int>()  
        var a = x
        while(answer.size != n){
            answer.add(a)
            a += a
        }
                
        return answer
    }
}

이렇게 했더니 리스트에서 자꾸 오류가 뜬다.

error: unresolved reference: mutableListOf
fun solution(x: Int, n: Int): mutableListOf<Int> 

class Solution {
    fun solution(x: Int, n: Int): MutableList<Int> {
        var answer = mutableListOf<Int>()  
        var a = x
        while(answer.size != n){
            answer.add(a)
            a += a
        }                
        return answer
    }
}

컬렉션의 선언과 반환타입명시는 다르구나...

리스트 오류는 해결했는데 이젠 결과값이 뒤죽박죽이다.

 

class Solution {
    fun solution(x: Int, n: Int): MutableList<Int> {
        var answer = mutableListOf<Int>()  
        var a = x
        while(answer.size != n){
            answer.add(a)
            a += x
        }                
        return answer
    }
}

a += a 를 하면 계속 커지는 a 값을 더하게 되는데 이게 아니라

일정한 x의 간격을 가져야 하므로 더해주는 값은 x여야 한다.

그리고 다시 시도했는데

마지막 두 문제에서 실패한다

다른 사람들도 다 그런 듯...뭐가 문제일까?!

 

/SolutionRunner.kt:47:28: error: type mismatch: inferred type is Int but Long was expected runner.run({ sol.solution(p0_0,p0_1) })

/Solution.kt:7:24: error: type mismatch: inferred type is Int but Long was expected answer.add(a)

자꾸 입력값이랑 반환타입이 다르다길래 그냥 변수선언할 때  long 타입으로 바꿨다. 그러니까 통과되네...

 

 

해결

class Solution {
    fun solution(x: Int, n: Int): MutableList<Long> {
        var answer = mutableListOf<Long>()  
        var a:Long = x.toLong()
        
        while(answer.size < n){
            answer.add(a)
            a += x
        }                
        return answer
    }
}

 

 

x 를 Long 타입으로 변환하는 이유

: overflow 방지

 

x는 -10000000 이상 10000000 이하인 정수로 여기서 x의 간격만큼 커지니 그 크기는 배가 된다.

이 때 반환되는 결과값은 Int 의 범위를 초과할 수 있고 그러면 overflow 가 발생해 예상치 못한 결과가 나올 수 있다. 그러므로 x 를 Long 타입으로 변환하여 연산 중에 보호하는 것

 

*Long 타입 

: 64비트의 부호 있는 정수 

*overflow 

: 데이터 타입이 나타낼 수 있는 범위를 초과하여 저장하려고 할 때 발생

 값의 순환으로 음수로 바뀌거나 실제 결과와 다른 값이 나오거나 프로그램이 비정상적으로 종료될 수 있다.

 

 

 

 

다른 사람 풀이

이게 무슨 뜻일까!

 

class Solution {
    fun solution(x: Int, n: Int): LongArray 
    = LongArray(n) //길이가 n인 Long 타입의 배열 생성
    { x.toLong() * (it + 1) } // {} : 배열의 각 요소 초기화
}                             // it : 인덱스 (0부터 시작하므로 간격이 x인 숫자 n개를 만들기 위해
                              //      1을 더해준 값에 x를 곱해준다)
                              //      첫 번째 숫자는 x*1, 두 번째 숫자는 x*2, n번째 숫자는 x*n

일정한 간격이라길래 나는 냅다 반복문부터 돌렸는데...

아는게 있어야 활용을 하네

꼭 복습하고 기억해야지