본문 바로가기
코딩테스트/자바 Level 0

[Java] 수열과 구간 쿼리 3

by onggury 2023. 7. 28.

문제

정수 배열 arr와 2차원 정수 배열 queries이 주어집니다. queries의 원소는 각각 하나의 query를 나타내며, [i, j] 꼴입니다.

 

각 query마다 순서대로 arr[i]의 값과 arr[j]의 값을 서로 바꿉니다.

 

위 규칙에 따라 queries를 처리한 이후의 arr를 return 하는 solution 함수를 완성해 주세요.

 

 

제한사항

  • 1 ≤ arr 의 길이 ≤ 1,000
    • 0 ≤ arr 의 원소 ≤ 1,000,000
  • 1 ≤ queries 의 길이 ≤ 1,000
    • 0 ≤ i < j < arr 의 길이

 

import java.util.Arrays;

class Solution {
    public int[] solution(int[] arr, int[][] queries) {
        int[] answer = Arrays.copyOfRange(arr, 0, arr.length);
        
        for(int[] query : queries) {
            int tmp = answer[query[0]];
            answer[query[0]] = answer[query[1]];
            answer[query[1]] = tmp;
        }
        return answer;
    }
}

원본 arr을 건들고싶지 않아서 answer 배열에 깊은복사를 했다.

 

 

 

출처

https://school.programmers.co.kr/learn/courses/30/lessons/181924