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
일정한 간격이라길래 나는 냅다 반복문부터 돌렸는데...
아는게 있어야 활용을 하네
꼭 복습하고 기억해야지
'코딩테스트' 카테고리의 다른 글
프로그래머스 정수 제곱근 판별 (0) | 2023.12.18 |
---|---|
프로그래머스 자연수 뒤집어 배열로 만들기 (1) | 2023.12.15 |
프로그래머스 나머지가 1이 되는 수 찾기 (0) | 2023.12.13 |
프로그래머스 약수의 합 (0) | 2023.12.12 |
프로그래머스 짝수와 홀수, 평균 구하기, 자릿수 더하기 (1) | 2023.12.11 |