Notice
Recent Posts
Recent Comments
Link
일 | 월 | 화 | 수 | 목 | 금 | 토 |
---|---|---|---|---|---|---|
1 | 2 | 3 | 4 | 5 | ||
6 | 7 | 8 | 9 | 10 | 11 | 12 |
13 | 14 | 15 | 16 | 17 | 18 | 19 |
20 | 21 | 22 | 23 | 24 | 25 | 26 |
27 | 28 | 29 | 30 | 31 |
Tags
- 자바
- snapshotflow
- 명령형 ui
- State
- mutablestate
- Java
- compose
- 2022 kakao blind
- 명령형ui
- 선언형ui
- ModalBottomSheet
- NavHost
- JCF
- NavGraph
- 양과 늑대
- 안드로이드
- 클린아키텍처
- BottomSheet
- 2022 KAKAO BLIND RECRUITMENT
- apollo3
- 2989번
- rememberupdatedstate
- producestate
- 선언형 ui
- genarics
- remembercoroutinescope
- bottomscaffold
- mutableStateOf
- derivedstateof
- clean coder
Archives
- Today
- Total
버미
프로그래머스 qr code 본문
문제 설명
두 정수 q
, r
과 문자열 code
가 주어질 때, code
의 각 인덱스를 q
로 나누었을 때 나머지가 r
인 위치의 문자를 앞에서부터 순서대로 이어 붙인 문자열을 return 하는 solution 함수를 작성.
제한사항
- 0 ≤
r
<q
≤ 20 r
<code
의 길이 ≤ 1,000code
는 영소문자로만 이루어져 있습니다.
입출력 예
q r code result
3 1 "qjnwezgrpirldywt" "jerry"
1 0 "programmers" "programmers"
문제 풀이
#include <stdio.h>
#include <stdbool.h>
#include <stdlib.h>
#include <string.h>
char* solution(int q, int r, const char* code) {
int size = strlen(code);
int max_size = size / q + 1;
char* answer = malloc((max_size + 1) * sizeof(char));
int cnt = 0;
for (int i = 0; i < size; i++) {
if ((i % q) == r) {
char* temp = malloc((cnt + 2) * sizeof(char));
if (temp != NULL) {
memcpy(temp, answer, cnt);
temp[cnt] = code[i];
temp[cnt + 1] = '\0';
free(answer);
answer = temp;
cnt++;
}
}
}
return answer;
}
문제에서 제시한 동적 할당을 생각하다보니까 문제 풀이하는데 오래걸렸다. 다른 사람들이 풀어낸 풀이 코드를 보면
char* answer = (char*)malloc(10000);
와 같이 풀어도 해당 문제는 상관 없었을 것 같았다.
'코딩 트레이닝' 카테고리의 다른 글
백준 2563번 - 색종이(c언어) (0) | 2023.07.07 |
---|---|
백준 10844번 - 쉬운 계단 수(C언어) (0) | 2023.07.06 |
프로그래머스 3진법 뒤집기 (0) | 2023.07.05 |
백준 1157번 - 단어 공부 (0) | 2023.07.04 |
프로그래머스 - 문자열 계산하기 (0) | 2023.07.03 |