[프로그래머스] 가위 바위 보
카테고리 : 컴퓨터 공학
태그: programmers · Code Refactoring · 참고 할 만한 다른 사람의 코드 · 코딩 기초 트레이닝 · 프로그래머스 · 코딩테스트 연습 · JavaScript · 가위 바위 보 · js 가위 바위 보
태그: programmers · Code Refactoring · 참고 할 만한 다른 사람의 코드 · 코딩 기초 트레이닝 · 프로그래머스 · 코딩테스트 연습 · JavaScript · 가위 바위 보 · js 가위 바위 보
문제 설명
가위는 2 바위는 0 보는 5로 표현합니다. 가위 바위 보를 내는 순서대로 나타낸 문자열 rsp
가 매개변수로 주어질 때, rsp에 저장된 가위 바위 보를 모두 이기는 경우를 순서대로 나타낸 문자열을 return하도록 solution 함수를 완성해보세요.
제한사항
- 0 <
rsp
의 길이 ≤ 100 rsp
와 길이가 같은 문자열을 return 합니다.rsp
는 숫자 0, 2, 5로 이루어져 있습니다.
입출력 예
rsp | result |
---|---|
“2” | “0” |
“205” | “052” |
입출력 예 설명
입출력 예 #1
- “2”는 가위이므로 바위를 나타내는 “0”을 return 합니다.
입출력 예 #2
- “205”는 순서대로 가위, 바위, 보이고 이를 모두 이기려면 바위, 보, 가위를 순서대로 내야하므로 “052”를 return합니다.
나의 풀이
function solution(rsp) {
return (answer = [...rsp]
.map((item) => {
switch (item) {
case "2":
return 0;
case "0":
return 5;
case "5":
return 2;
}
})
.join(""));
}
나의 두번째 풀이(Code Refactoring)
function solution(rsp) {
let result = "";
for (i = 0; i < rsp.length; i++) {
if (rsp[i] === "2") {
result += "0";
}
if (rsp[i] === "0") {
result += "5";
}
if (rsp[i] === "5") {
result += "2";
}
}
return result;
}
// for문으로 가위바위보
참고 할 만한 다른 사람의 코드
function solution(rsp) {
let arr = {
2: 0,
0: 5,
5: 2,
};
var answer = [...rsp].map((v) => arr[v]).join("");
return answer;
}
// 객체의 key value로 가위바위보