Posis

[프로그래머스] 가위 바위 보 본문

알고리즘/프로그래머스

[프로그래머스] 가위 바위 보

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