저장을 습관화
프로그래머스 LV.0 수 조작하기 2 본문
프로그래머스 LV.0 수 조작하기 2
https://school.programmers.co.kr/learn/courses/30/lessons/181925
프로그래머스
코드 중심의 개발자 채용. 스택 기반의 포지션 매칭. 프로그래머스의 개발자 맞춤형 프로필을 등록하고, 나와 기술 궁합이 잘 맞는 기업들을 매칭 받으세요.
programmers.co.kr
1. 문제 명
수 조작하기 2
2. 문제 설명
정수 배열 numLog가 주어집니다. 처음에 numLog[0]에서 부터 시작해 "w", "a", "s", "d"로 이루어진 문자열을 입력으로 받아 순서대로 다음과 같은 조작을 했다고 합시다.
- "w" : 수에 1을 더한다.
- "s" : 수에 1을 뺀다.
- "d" : 수에 10을 더한다.
- "a" : 수에 10을 뺀다.
그리고 매번 조작을 할 때마다 결괏값을 기록한 정수 배열이 numLog입니다. 즉, numLog[i]는 numLog[0]로부터 총 i번의 조작을 가한 결과가 저장되어 있습니다.
주어진 정수 배열 numLog에 대해 조작을 위해 입력받은 문자열을 return 하는 solution 함수를 완성해 주세요.
3. 제한 사항
- 2 ≤ numLog의 길이 ≤ 100,000
- -100,000 ≤ numLog[0] ≤ 100,000
- 1 ≤ i ≤ numLog의 길이인 모든 i에 대해 |numLog[i] - numLog[i - 1]|의 값은 1 또는 10입니다.
4. 예시
numLog | result |
[0, 1, 0, 10, 0, 1, 0, 10, 0, -1, -2, -1] | "wsdawsdassw" |
5. 기본 제공 코드
function solution(numLog) {
var answer = '';
return answer;
}
6. 제출한 내 답
const solution = (numLog) => {
cal = {
"+1": "w",
"-1": "s",
"+10": "d",
"-10": "a",
};
return numLog
.reduce((a, b, i) => {
return b < numLog[i + 1]
? a + cal[`+${numLog[i + 1] - b}`]
: a + cal[`-${b - numLog[i + 1]}`];
}, "")
.replace(undefined, "");
};
6-2. VSC에 작성한 내용
const solution = (numLog) => {
cal = {
"+1": "w",
"-1": "s",
"+10": "d",
"-10": "a",
};
// let a = [];
// for (i = 1; i < numLog.length; i++) {
// // numLog[i-1]과 numLog[i]를 비교해서 차이를 기록하고 싶어
// // 계산식은 더하기 아니면 빼기 밖에 없어 현상 유지는 없어
// if (numLog[i - 1] < numLog[i]) {
// a.push(`+${numLog[i] - numLog[i - 1]}`);
// } else {
// a.push(`-${numLog[i - 1] - numLog[i]}`);
// }
// }
return numLog
.reduce((a, b, i) => {
return b < numLog[i + 1]
? a + cal[`+${numLog[i + 1] - b}`]
: a + cal[`-${b - numLog[i + 1]}`];
}, "")
.replace(undefined, "");
// return a.reduce((a, b) => {
// return a + cal[b];
// }, "");
};
// 테스트
console.log(solution([0, 1, 0, 10, 0, 1, 0, 10, 0, -1, -2, -1]));
// +1 -1 +10 -10 +10 -10 +10 -10 -1 -2 +1
7. 특이사항
최근 풀었던 것 중에 가장 헷갈렸던것 같다
for문으로 한번 풀었으니 배열 메소드도 써보자 했는데 너무 오래 걸렸다
8. 다른 사람이 작성한 답
8-1. map
function solution(numLog) {
const convert = {
'1': 'w', '-1': 's', '10': 'd', '-10': 'a'
};
return numLog.slice(1).map((v, i) => {
return convert[v - numLog[i]]
}).join('')
}
slice로 맨 앞에 있는 요소를 지웠는데
numLog[0]이 0이 아니었으면 어떡하려고..?
8-2. switch case
function solution(numLog) {
//w +1,a-10,s-1,d+10
let array = [...numLog]
let answer = [];
for(let i=0;i<array.length;i++){
switch(array[i+1]-array[i]){
case 1:
answer.push('w')
break;
case -1:
answer.push('s')
break
case 10:
answer.push('d')
break;
case -10:
answer.push('a')
break;
}
}
return answer.join('');
}
8-3. switch case
function solution(numLog) {
let answer ="";
for(let i = 0 ; i < numLog.length-1 ; i++ ){
const val = numLog[i+1] - numLog[i];
switch(val){
case 1: answer+="w";break;
case -10: answer+="a";break;
case -1: answer+="s";break;
case +10: answer+="d";break;
}
}
return answer;
}
'코딩 테스트 > 프로그래머스 - 자바스크립트' 카테고리의 다른 글
프로그래머스 LV.0 등차수열의 특정한 항만 더하기 (0) | 2023.09.21 |
---|---|
프로그래머스 LV.2 최댓값과 최솟값 (0) | 2023.09.21 |
프로그래머스 LV.0 배열 만들기 3 (0) | 2023.09.21 |
프로그래머스 LV.0 주사위 게임 2 (0) | 2023.09.21 |
프로그래머스 LV.0 인덱스 바꾸기 (0) | 2023.09.21 |