문제설명
문자열 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;
}
}
*다른 코드
class Solution {
public String solution(String my_string, int[] index_list) {
StringBuilder sb = new StringBuilder();
for (int idx : index_list)
sb.append(my_string.charAt(idx));
return sb.toString();
}
}
Python
def solution(my_string, index_list):
answer = ""
for i in index_list:
answer += my_string[i]
return answer
*다른 코드
def solution(my_string, index_list):
return ''.join([my_string[idx] for idx in index_list])
JS
function solution(my_string, index_list) {
var answer = '';
for(var i=0; i<index_list.length; i++){
answer += my_string[index_list[i]];
}
return answer;
}
*다른 코드
function solution(my_string, index_list) {
return index_list.map(i => my_string[i]).join('')
}
'프로그래머스 Lv.0' 카테고리의 다른 글
Lv.0 문자열 여러 번 뒤집기 (0) | 2025.02.04 |
---|---|
Lv.0 9로 나눈 나머지 (0) | 2025.02.04 |
Lv.0 주사위 게임 3 (0) | 2025.02.03 |
Lv.0 간단한 논리 연산 (1) | 2025.02.02 |
Lv.0 배열 만들기 4 (0) | 2025.02.02 |