알고리즘/프로그래머스
[프로그래머스] 가위 바위 보
CooNiHong
2022. 12. 5. 16:49
문제 링크
https://school.programmers.co.kr/learn/courses/30/lessons/120839
프로그래머스
코드 중심의 개발자 채용. 스택 기반의 포지션 매칭. 프로그래머스의 개발자 맞춤형 프로필을 등록하고, 나와 기술 궁합이 잘 맞는 기업들을 매칭 받으세요.
programmers.co.kr
문제 설명
가위는 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합니다.
나의 풀이
Java
class Solution {
public String solution(String rsp) {
String answer = "";
String[] strArr = rsp.split("");
for(int i = 0; i < strArr.length; i++) {
if(strArr[i].equals("2")) answer += "0";
else if(strArr[i].equals("0")) answer += "5";
else if(strArr[i].equals("5")) answer += "2";
}
return answer;
}
}
JavaScript
function solution(rsp) {
let arr = {
2: 0,
0: 5,
5: 2
};
var answer = [...rsp].map(v => arr[v]).join("");
return answer;
}
JavaScript는 비구조화 할당을 이용해서 key값으로 value를 뽑아와서 문자열을 합쳤습니다.
728x90