728x90
반응형
문제 설명
문자열 my_string과 정수 배열 index_list가 매개변수로 주어집니다. my_string의 index_list의 원소들에 해당하는 인덱스의 글자들을 순서대로 이어 붙인 문자열을 return 하는 solution 함수를 작성해 주세요.
제한사항
1 ≤ my_string의 길이 ≤ 1,000
my_string의 원소는 영소문자로 이루어져 있습니다.
1 ≤ index_list의 길이 ≤ 1,000
0 ≤ index_list의 원소 < my_string의 길이
입출력 예
my_string index_list result
"cvsgiorszzzmrpaqpe" [16, 6, 5, 3, 12, 14, 11, 11, 17, 12, 7]"programmers"
"zpiaz" [1, 2, 0, 0, 3] "pizza"
입출력 설명
입출력 예 #1
예제 1번의 my_string에서 인덱스 3, 5, 6, 11, 12, 14, 16, 17에 해당하는 글자는 각각 g, o, r, m, r, a, p, e이므로 my_string에서 index_list에 들어있는 원소에 해당하는 인덱스의 글자들은 각각 순서대로 p, r, o, g, r, a, m, m, e, r, s입니다. 따라서 "programmers"를 return 합니다.
입출력 예 #2
예제 2번의 my_string에서 인덱스 0, 1, 2, 3에 해당하는 글자는 각각 z, p, i, a이므로 my_string에서 index_list에 들어있는 원소에 해당하는 인덱스의 글자들은 각각 순서대로 p, i, z, z, a입니다. 따라서 "pizza"를 return 합니다.
내 풀이
Java
class Solution {
public String solution(String my_string, int[] index_list) {
String answer = "";
for(int i = 0; i < index_list.length; i++){
answer += my_string.charAt(index_list[i]);
}
return answer;
}
}
C
#include <stdio.h>
#include <stdbool.h>
#include <stdlib.h>
// index_list_len은 배열 index_list의 길이입니다.
// 파라미터로 주어지는 문자열은 const로 주어집니다. 변경하려면 문자열을 복사해서 사용하세요.
char* solution(const char* my_string, int index_list[], size_t index_list_len) {
// return 값은 malloc 등 동적 할당을 사용해주세요. 할당 길이는 상황에 맞게 변경해주세요.
char* answer = (char*)malloc(sizeof(char) * index_list_len + 1);
int i;
for(i = 0; i < index_list_len; i++){
answer[i] = my_string[index_list[i]];
}
answer[i] = '\0';
return answer;
}
Python
def solution(my_string, index_list):
answer = ''
for i in index_list:
answer += my_string[i]
return answer
https://school.programmers.co.kr/learn/courses/30/lessons/181915
프로그래머스
SW개발자를 위한 평가, 교육, 채용까지 Total Solution을 제공하는 개발자 성장을 위한 베이스캠프
programmers.co.kr
728x90
반응형
'코딩테스트 > 프로그래머스 기초' 카테고리의 다른 글
[코딩테스트 Lv.0] 간단한 논리 연산 (3) | 2025.03.24 |
---|---|
[코딩테스트 Lv.0] 주사위 게임 3 (5) | 2025.03.24 |
[코딩테스트 Lv.0] 9로 나눈 나머지 (2) | 2025.03.22 |
[코딩테스트 Lv.0] 문자열 여러 번 뒤집기 (11) | 2025.03.21 |
[코딩테스트 Lv.0] 배열 만들기 5 (4) | 2025.03.19 |