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번이 실행되지 않았다.
망할놈의 동적할당..ㅋㅋ;