728x90
반응형
문제 설명
두 정수 q, r과 문자열 code가 주어질 때, code의 각 인덱스를 q로 나누었을 때 나머지가 r인 위치의 문자를 앞에서부터 순서대로 이어 붙인 문자열을 return 하는 solution 함수를 작성해 주세요.
제한사항
0 ≤ r < q ≤ 20
r < code의 길이 ≤ 1,000
code는 영소문자로만 이루어져 있습니다.
입출력 예
q r code result
3 1 "qjnwezgrpirldywt" "jerry"
1 0 "programmers" "programmers"
입출력 설명
입출력 예 #1
예제 1번의 q와 r은 각각 3, 1이고 인덱스와 그 값을 q로 나눈 나머지가 잘 보이도록 표로 만들면 다음과 같습니다.
code q j n w e z g r p i r l d y w t
index 0 1 2 3 4 5 6 7 8 9 10 11 12 13 14 15
q로 나눈 나머지 0 1 2 0 1 2 0 1 2 0 1 2 0 1 2 0
`q`로 나눈 나머지가 1인 인덱스의 문자들을 앞에서부터 순서대로 이어 붙이면 "jerry"가 되므로 이를 return 합니다.
입출력 예 #2
예제 2번의 q와 r은 각각 1, 0이고 인덱스와 그 값을 q로 나눈 나머지가 잘 보이도록 표로 만들면 다음과 같습니다.
code p r o g r a m m e r s
index 0 1 2 3 4 5 6 7 8 9 10
q로 나눈 나머지 0 0 0 0 0 0 0 0 0 0 0
`q`로 나눈 나머지가 1인 인덱스의 문자들을 앞에서부터 순서대로 이어 붙이면 "programmers"가 되므로 이를 return 합니다.
내 풀이
Java
class Solution {
public String solution(int q, int r, String code) {
String answer = "";
for(int i = 0; i < code.length(); i++){
if(i % q == r){
answer += code.charAt(i);
}
}
return answer;
}
}
C
#include <stdio.h>
#include <stdbool.h>
#include <stdlib.h>
// 파라미터로 주어지는 문자열은 const로 주어집니다. 변경하려면 문자열을 복사해서 사용하세요.
char* solution(int q, int r, const char* code) {
// return 값은 malloc 등 동적 할당을 사용해주세요. 할당 길이는 상황에 맞게 변경해주세요.
char* answer = (char*)malloc(sizeof(char) * strlen(code) + 1);
int i, k;
for(i = 0, k = 0; i < strlen(code); i++){
if(i % q == r){
answer[k++] = code[i];
}
}
answer[k] = '\0';
return answer;
}
Python
def solution(q, r, code):
answer = code[r::q]
return answer
https://school.programmers.co.kr/learn/courses/30/lessons/181903
프로그래머스
SW개발자를 위한 평가, 교육, 채용까지 Total Solution을 제공하는 개발자 성장을 위한 베이스캠프
programmers.co.kr
728x90
반응형
'코딩테스트 > 프로그래머스 기초' 카테고리의 다른 글
[코딩테스트 Lv.0] 문자열 뒤집기 (4) | 2025.03.13 |
---|---|
[코딩테스트 Lv.0] 세로 읽기 (1) | 2025.03.13 |
[코딩테스트 Lv.0] 문자 개수 세기 (1) | 2025.03.13 |
[코딩테스트 Lv.0] 배열 만들기 1 (5) | 2025.03.13 |
[코딩테스트 Lv.0] 글자 지우기 (1) | 2025.03.13 |