c언어

[C언어/프로그래머스 레벨0]-가위 바위 보

이상한 코딩 2022. 10. 30. 23:04
728x90


문제 설명


가위는 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합니다.

[소스코드]

#include <stdio.h>
#include <string.h>

char* solution(const char* rsp) {
    char* answer = (char*)calloc(1,sizeof(char)*100);
    //주먹 '0' 가위 '2' 보 '5'
    
    for(int i=0;i<strlen(rsp);i++){
        if(rsp[i]=='5')
           answer[i]='2';
       
       if(rsp[i]=='2')
           answer[i]='0';
       
       if(rsp[i]=='0')
           answer[i]='5';
   }
    
    return answer;
}

문자열을 그냥 집어넣는 아주 간단한 알고리즘이다.
switch case 문으로 해도 되는데 for문으로 하는게 더
간결해 보여서 작성했다.
주의할 점은 동적할당을 잘해줘야 하는것, malloc을 사용하지 않고 calloc을 사용했는데
calloc(1,sizeof(char)*100) 부분에서 배열 값을 0으로 하거나, *100을 하지않으니 예제 7번이 실행되지 않았다.
망할놈의 동적할당..ㅋㅋ;