본문 바로가기
코딩 문제/프로그래머스 [ JavaScript ]

[ 프로그래머스 / JavaScript ] 자릿수 더하기

by CODESIGN 2022. 9. 19.

 

https://school.programmers.co.kr/learn/courses/30/lessons/12931

 

프로그래머스

코드 중심의 개발자 채용. 스택 기반의 포지션 매칭. 프로그래머스의 개발자 맞춤형 프로필을 등록하고, 나와 기술 궁합이 잘 맞는 기업들을 매칭 받으세요.

programmers.co.kr

 

문제 설명

자연수 N이 주어지면, N의 각 자릿수의 합을 구해서 return 하는 solution 함수를 만들어 주세요.
예를들어 N = 123이면 1 + 2 + 3 = 6을 return 하면 됩니다.

제한사항
  • N의 범위 : 100,000,000 이하의 자연수

 

입출력 예

N answer
123 6
987 24

 

입출력 예 설명

입출력 예 #1
문제의 예시와 같습니다.

 

입출력 예 #2
9 + 8 + 7 = 24이므로 24를 return 하면 됩니다.

 


나의 문제풀이

주어진 예제 1의 n이 123일때,

123을 toString()을 사용하여 string으로 변환을 시켜준뒤

split()으로 "123"을 [ "1", "2", "3"]으로 변환한다.

배열의 값들을 더해주기 위해 Number로 형변환을 시켜준뒤

reduce()를 사용하여 값들을 더해 줬다.

 

function solution(n) {
    return n.toString().split("").map(Number).reduce((acc,cur,i) => acc += cur,0);
}

 

 

[ 자바스크립트 ] reduce() 함수 이해하기

구문 arr.reduce(callback[, initialValue]); reduce() 함수는 네 개의 인자를 가진다. 누산기 (acc) 현재 값 (cur) 현재 인덱스 (idx) 원본 배열 (src) reduce() 함수의 반환 값은 누산기에 할당되고, 누산기는..

codesign.tistory.com

 

 


다른 풀이

 

내가 푼 방법과 비슷하며 runtime도 비슷하다. 

 

새로 알게 된것은 n에 ""를 더해줌으로써 n을 string으로 변환 시켰다.

 

function solution(n) {
    return (n+"").split("").reduce((acc, curr) => acc + parseInt(curr), 0)
}

 

 

댓글