첫번째 - 문자열 뒤집기
문자열 my_string이 매개변수로 주어집니다. my_string을 거꾸로 뒤집은 문자열을 return하도록 solution 함수를 완성해주세요.
입출력 예
| my_string | return |
| "jaron" | "noraj" |
| "bread" | "daerb" |
#include <stdio.h>
#include <stdbool.h>
#include <stdlib.h>
// 파라미터로 주어지는 문자열은 const로 주어집니다. 변경하려면 문자열을 복사해서 사용하세요.
char* solution(const char* my_string) {
// return 값은 malloc 등 동적 할당을 사용해주세요. 할당 길이는 상황에 맞게 변경해주세요.
int len = strlen(my_string);
char* answer = (char*)malloc(1);
char temp;
int i;
for(i=0;i<len;i++)
answer[i]=my_string[len-1-i];
answer[i]='\0';
return answer;
}
strlen 함수를 통해 문자열의 길이를 구한 후
문자열의 끝에서부터 반복문을 돌려
하나씩 answer에 넣어주면 된다
두번째 - 직각삼각형 출력하기
"*"의 높이와 너비를 1이라고 했을 때, "*"을 이용해 직각 이등변 삼각형을 그리려고합니다. 정수 n 이 주어지면 높이와 너비가 n 인 직각 이등변 삼각형을 출력하도록 코드를 작성해보세요.
입출력 예
입력 #1
3
출력 #1
*
**
***
#include <stdio.h>
void print(int n);
int main(void) {
int n;
scanf("%d", &n);
print(n);
return 0;
}
void print(int n)
{
int i, j;
for(i=1;i<=n;i++){
for(j=1;j<=i;j++)
printf("*");
printf("\n");
}
}
입력받은 숫자가 열의 길이가 되고,
중첩 반복문을 통해 열의 인덱스만큼 *을 찍어주면 된다
ex) 첫번째 열에는 * 한개, 두번째 열에는 두개...
세번째 - 짝수 홀수 개수
정수가 담긴 리스트 num_list가 주어질 때, num_list의 원소 중 짝수와 홀수의 개수를 담은 배열을 return 하도록 solution 함수를 완성해보세요.
입출력 예
| num_list | result |
| [1, 2, 3, 4, 5] | [2, 3] |
| [1, 3, 5, 7] | [0, 4] |
#include <stdio.h>
#include <stdbool.h>
#include <stdlib.h>
// num_list_len은 배열 num_list의 길이입니다.
int* solution(int num_list[], size_t num_list_len) {
// return 값은 malloc 등 동적 할당을 사용해주세요. 할당 길이는 상황에 맞게 변경해주세요.
int* answer = (int*)malloc(1);
int i, evenN=0, oddN=0;
for(i=0;i<num_list_len;i++){
if(num_list[i]%2==0)
evenN++;
else
oddN++;
}
answer[0]=evenN;
answer[1]=oddN;
return answer;
}
전체 데이터가 들어있는 배열을 반복문을 사용해 돌리고
하나씩 검사를 해서
짝수면 evenN을 하나씩 증가시키고,
홀수면 oddN을 하나씩 증가시킨다
마지막에 answer에 넣어주면 끝!
네번째 - 문자 반복 출력하기
문자열 my_string과 정수 n이 매개변수로 주어질 때, my_string에 들어있는 각 문자를 n만큼 반복한 문자열을 return 하도록 solution 함수를 완성해보세요.
입출력 예
| my_string | n | result |
| "hello" | 3 | "hhheeellllllooo" |
#include <stdio.h>
#include <stdbool.h>
#include <stdlib.h>
// 파라미터로 주어지는 문자열은 const로 주어집니다. 변경하려면 문자열을 복사해서 사용하세요.
char* solution(const char* my_string, int n) {
// return 값은 malloc 등 동적 할당을 사용해주세요. 할당 길이는 상황에 맞게 변경해주세요.
char* answer = (char*)malloc(strlen(my_string)*n);
int i, j, len=0;
for(i=0;my_string[i]!='\0';i++)
for(j=0;j<n;j++)
answer[len++]=my_string[i];
answer[len]='\0';
return answer;
}
answer의 인덱스를 따로 변수로 잡아주고
my_string[i]를 n만큼 반복해서 answer에 넣어주면 된다
'프로그래머스 코딩테스트' 카테고리의 다른 글
| 프로그래머스 코딩테스트 입문 DAY8 (0) | 2024.02.04 |
|---|---|
| 프로그래머스 코딩테스트 입문 DAY7 (1) | 2024.02.04 |
| 프로그래머스 코딩테스트 입문 DAY5 (0) | 2024.02.04 |
| 프로그래머스 코딩테스트 입문 DAY4 (0) | 2024.02.04 |
| 프로그래머스 코딩테스트 입문 DAY3 (0) | 2024.02.03 |