📝24.01.10
🔗 문제 : https://school.programmers.co.kr/learn/courses/30/lessons/120839
문제 설명
가위는 2 바위는 0 보는 5로 표현합니다. 가위 바위 보를 내는 순서대로 나타낸 문자열 rsp가 매개변수로 주어질 때, rsp에 저장된 가위 바위 보를 모두 이기는 경우를 순서대로 나타낸 문자열을 return하도록 solution 함수를 완성해보세요.
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;
}
}
사실 위의 풀이가 잘못된 것은 아니고, 또 다수가 저렇게 풀었다. (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++의 경우에는 이것보다 더 좋은 풀이가 없었다.
#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;
}