Notice
Tags
- Algorithm
- JavaScript
- programmers
- html
- composition api
- amplify
- javascirpt
- 백준
- preload
- TypeScript
- S3
- 자바스크립트
- SSH
- 모던자바스크립트DeepDive
- github
- fetchpriority
- AWS
- Prefetch
- 캐시무효화
- eslint
- 프로그래머스
- IntersectionObserverAPI
- CF
- nuxt
Recent Posts
Archives
우주선
[프로그래머스][javascript] 124 나라의 숫자 본문
[문제]
124 나라가 있습니다. 124 나라에서는 10진법이 아닌 다음과 같은 자신들만의 규칙으로 수를 표현합니다.
- 124 나라에는 자연수만 존재합니다.
- 124 나라에는 모든 수를 표현할 때 1, 2, 4만 사용합니다.
예를 들어서 124 나라에서 사용하는 숫자는 다음과 같이 변환됩니다.
10진법 | 124나라 | 10진법 | 124나라 |
1 | 1 | 6 | 14 |
2 | 2 | 7 | 21 |
3 | 4 | 8 | 22 |
4 | 11 | 9 | 24 |
5 | 12 | 10 | 41 |
자연수 n이 매개변수로 주어질 때, n을 124 나라에서 사용하는 숫자로 바꾼 값을 return 하도록 solution 함수를 완성해 주세요.
제한사항
- n은 500,000,000이하의 자연수 입니다.
[ 내가 푼 것 ]
function solution(n) {
if(n <= 500000000){
let answer = '';
for (let i = n; i > 0; i = parseInt(i / 3)) {
let result = i % 3
if (result === 0) {
result = 4
i--
}
answer = result + answer
}
return answer
}
}
매개변수 n이 500,000,000이하의 자연수라는 제한사항이 있어서 if문 걸어줬고
for로 반복문 돌려서 몫이 0이 될때까지 3으로 나눠주고
반복문 안에서
n을 3으로 나눈 나머지를 result로 받아서 answer를 삼진수로 바꿔줬고
3진수는 0,1,2 인데 124나라는 1,2,4니까 나머지가 0인 경우에
0을 4로 바꿔주고 , 3의 배수이므로 삼진수로는 자릿수가 바뀌기 때문에 i에 -1을 해준다.
그리고 answer를 리턴하면 끝이다... !
... 이었는데?
[ '다른 사람의 풀이' 가서 본건데 멋진 것 ,,,]
function change124(n) {
return n === 0 ? '' : change124(parseInt((n - 1) / 3)) + [1, 2, 4][(n - 1) % 3];
}
재귀함수와 배열 인덱스를 이용해 한 줄로 줄여버린 사람이 있었다 ; 와우 ;
생각해보면 n-1 을 처음부터 해줘도 몫에는 변함이 없으니 ... parseInt(n/3)과 parseInt((n-1)/3)은 동일하니까 ...
문제는 여기
https://programmers.co.kr/learn/courses/30/lessons/12899
코딩테스트 연습 - 124 나라의 숫자
programmers.co.kr
'Algorithm' 카테고리의 다른 글
[프로그래머스][javascript]소수 찾기 (0) | 2022.04.03 |
---|---|
[프로그래머스][javascript] 모의고사 (0) | 2022.03.31 |
[프로그래머스][javascript] 기능개발 (0) | 2022.03.28 |
[백준][javascript] 15662번:톱니바퀴(2) (0) | 2022.03.27 |
[프로그래머스][javascript] 완주하지 못한 선수 (0) | 2022.03.27 |
Comments