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

김유원·2024년 1월 10일
0

📝24.01.10

🔗 문제 : https://school.programmers.co.kr/learn/courses/30/lessons/120839

문제 설명

가위는 2 바위는 0 보는 5로 표현합니다. 가위 바위 보를 내는 순서대로 나타낸 문자열 rsp가 매개변수로 주어질 때, rsp에 저장된 가위 바위 보를 모두 이기는 경우를 순서대로 나타낸 문자열을 return하도록 solution 함수를 완성해보세요.

[C#] 내가 작성한 풀이

using System;

public class Solution {
    public string solution(string rsp) {
        string answer = "";
        
        for(int i = 0; i < rsp.Length; i++) {
            switch(rsp[i]) {
                case '0':
                    answer += "5";
                    break;
                case '2':
                    answer += "0";
                    break;
                case '5':
                    answer+= "2";
                    break;
            }
        }
        
        return answer;
    }
}

[C#] 남이 작성한 풀이

사실 위의 풀이가 잘못된 것은 아니고, 또 다수가 저렇게 풀었다. (switch 대신 if를 사용한 것 정도의 차이는 있음)

하지만 하단의 풀이가 매우 인상적이었다. Linq를 적절히 사용하는 것이 중요한 것은 3일째 배우고 있는데 이것마저 Linq를 사용할 줄은 몰랐다...

특히 Select 로 x == 2인 경우 참이면 0, 거짓이면 x == 0인지 한번 더 판별하는 방식을 사용한게 매우 인상적이었다.

여기서 String.Concat() 함수는 참고로 여러 문자열을 하나로 연결하는 메서드이다.

using System;
using System.Linq;

public class Solution {
    public string solution(string rsp) {
        string answer = String.Concat(rsp.Select(x => x == '2' ? '0' : x == '0' ? '5' : '2'));
        return answer;
    }
}

[C++] 내가 작성한 풀이

C#과 동일하게 풀었다. C++의 경우에는 이것보다 더 좋은 풀이가 없었다.

#include <string>
#include <vector>

using namespace std;

string solution(string rsp) {
    string answer = "";
    
    for(int i = 0; i < rsp.length(); i++) {
        switch(rsp[i]) {
            case '0':
                answer += "5";
                break;
            case '2':
                answer += "0";
                break;
            case '5':
                answer += "2";
                break;
        }
    }
    return answer;
}
profile
개발 공부 블로그

0개의 댓글

관련 채용 정보