프로그래머스/0단계
문자열 여러 번 뒤집기
긴가우딘
2025. 1. 21. 00:13
문제 설명
문자열 my_string과 이차원 정수 배열 queries가 매개변수로 주어집니다. queries의 원소는 [s, e] 형태로, my_string의 인덱스 s부터 인덱스 e까지를 뒤집으라는 의미입니다. my_string에 queries의 명령을 순서대로 처리한 후의 문자열을 return 하는 solution 함수를 작성해 주세요.
문제 읽으면서 생각 정리
- s부터 e까지 추출해서 뒤집기
문제 풀면서 정리
- substring써서 자르고 += 했더니 자른 구간만 나옴
- 왼, 가운데, 오른쪽으로 나눠서 가운데 부분만 추출하여 뒤집고 다시 연결함
class Solution {
public String solution(String my_string, int[][] queries) {
for(int[] query : queries) {
String left = my_string.substring(0, query[0]);
String middle = my_string.substring(query[0], query[1] + 1);
String right = my_string.substring(query[1] + 1);
StringBuffer sb = new StringBuffer(middle);
String reverse = sb.reverse().toString();
my_string = left + reverse + right;
}
return my_string;
}
}