https://school.programmers.co.kr/learn/courses/30/lessons/181915
프로그래머스
코드 중심의 개발자 채용. 스택 기반의 포지션 매칭. 프로그래머스의 개발자 맞춤형 프로필을 등록하고, 나와 기술 궁합이 잘 맞는 기업들을 매칭 받으세요.
programmers.co.kr
문제 설명
문자열 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 합니다.
나의 문제 풀이
1) index_list의 숫자를 배열 인덱스로 인식시키기 위해 문자열을 배열로 만들었다.
2) for문을 통해 index_list를 순회 하였고 a라는 변수에 담았다.
3) answer에 배열로 만들어놨던 문자열의 인덱스가 추가 되도록 하였다.
4) 참고한 사이트 → https://amacoding.tistory.com/7
class Solution {
public String solution(String my_string, int[] index_list) {
String answer = "";
char[] str1 = my_string.toCharArray();
for(int i = 0; i < index_list.length; i++){
int a = index_list[i];
answer += str1[a];
}
return answer;
}
}
'코드문제풀이 > JAVA' 카테고리의 다른 글
[자바] 자릿수 더하기 (0) | 2023.07.06 |
---|---|
[자바] 이어 붙인 수 (0) | 2023.07.05 |
[자바] 문자열 섞기 (0) | 2023.07.05 |
[자바] n보다 커질 때까지... (0) | 2023.07.04 |
[자바] 두 수의 연산값 비교하기 (0) | 2023.07.03 |