프로그래머스의 코딩테스트 연습 > 코딩 기초 트레이닝 > 수 조작하기1 문제에 대한 문제 풀이입니다.
https://school.programmers.co.kr/learn/courses/30/lessons/181926
프로그래머스
코드 중심의 개발자 채용. 스택 기반의 포지션 매칭. 프로그래머스의 개발자 맞춤형 프로필을 등록하고, 나와 기술 궁합이 잘 맞는 기업들을 매칭 받으세요.
programmers.co.kr
먼저 문제는 아래와 같습니다. (문제의 전체 내용은 위 링크를 확인하시면 됩니다.)
문제설명
정수 n과 문자열 control이 주어집니다. control은 "w", "a", "s", "d"의 4개의 문자로 이루어져 있으며, control의 앞에서부터 순서대로 문자에 따라 n의 값을 바꿉니다.
- "w": n이 1 커집니다.
- "s": n이 1 작아집니다.
- "d": n이 10 커집니다.
- "a": n이 10 작아집니다.
위 규칙에 따라 n을 바꿨을 때 가장 마지막에 나오는 n의 값을 return 하는 solution 함수를 완성해 주세요.
입출력 예
n | control | result |
0 | "wsdawsdassw" | -1 |
풀이
수가 n부터 시작하므로 모든 control 요소의 값을 더한 후 n에 더해주면 되는 문제입니다. for 문과 if 문을 사용해서 작성해보면 아래처럼 작성할 수 있습니다.
function solution(n, control) {
for (let inx=0; inx<control.length; inx++) {
if (control[inx] === 'w') {
n = n + 1;
} else if (control[inx] === 's') {
n = n - 1;
} else if (control[inx] === 'd') {
n = n + 10;
} else {
n = n - 10;
}
}
return n;
}
위 내용은 누적값을 구하는 내용이므로 reduce 함수를 사용해서 아래와 같이 작성해 볼 수도 있습니다.
function solution(n, control) {
const point = {'w': 1, 's': -1, 'd': 10, 'a': -10}
return [...control].reduce((a, v) => a + point[v], n);
}
먼저 각 문자 당 수에 쉽게 접근하기 위해 문자와 수를 연결한 오브젝트를 하나 생성합니다.
전개 구문
아래와 같이 문자열에 전개 구문을 사용하면 해당 문자열을 배열로 변경할 수 있습니다.
const control = 'wsdawsdassw';
console.log([...control]);
//['w', 's', 'd', 'a', 'w', 's', 'd', 'a', 's', 's', 'w']
reduce 함수
reduce 함수는 배열을 순회하며 해당 배열 요소의 누적값을 구할 수 있습니다. 위와 같이 사용하면 초기값을 n으로 하여 point[v]의 값을 a에 누적한 후 return 하라는 의미입니다.
'프로그래머스 문제풀이 > Lv.0' 카테고리의 다른 글
"이어 붙인 수" 문제 풀이 (Lv.0) (0) | 2023.11.16 |
---|