티스토리 뷰

반응형

 

🤔 Arrays란?

✔ 배열을 다루기 편리한 메서드(static) 제공

 

✅ 배열의 출력 - toString()

✅ 배열 복사 - copyOf(), copyOfRange()

✅ 배열 채우기 - fill(), setAll()

✅ 배열의 정렬과 검색 - sort(), binarySearch()

(이진탐색은 정렬되어있을 때만 가능하므로

정렬 먼저 하고 binarySearch() 사용 해야 한다.)

 

int[] arr = {3, 2, 0, 1, 4};
int idx = Arrays.binarySearch(arr, 2); // idx=-5 잘못된 결과 (왜냐? 정렬되어 있지 않아서)

Arrays.sort(arr); // 배열 arr을 정렬한다.
System.out.println(Arrays.toString(arr)); // [0,1,2,3,4]
int idx = Arrays.binarySearch(arr, 2); // idx=2 올바른 결과

 

 

✅ 다차원 배열 출력 - deepToString()

✅ 다차원 배열의 비교 - deepEquals()

// deepToString()
int[] arr = {0,1,2,3,4};
int[][] arr2D = {{11,12}, {21,22}};

System.out.println(Arrays.toString(arr)); // [0,1,2,3,4]
System.out.println(Arrays.deepToString(arr2D)); // [[11,12], [21, 22]]

// deepEquals() 
String[][] str2D = new String[][]{{"aaa", "bbb"}, {"AAA", "BBB"}};
String[][] str2D2 = new String[][]{{"aaa", "bbb"}, {"AAA", "BBB"}};

System.out.println(Arrays.equals(str2D, str2D2)); // false
System.out.println(Arrays.deepEquals(str2D, str2D2)); // true

 

 

✅ 배열을 List로 변환 - asList(Object... a)

가변 매개변수 (갯수가 정해져있지 않다)

 

// 읽기 전용
List list = Arrays.asList(new Integer[]{1,2,3,4,5}); // list=[1,2,3,4,5]
List list = Arrays.asList(1,2,3,4,5); // list=[1,2,3,4,5]
list.add(6); // UnsupportedOperationException 예외 발생

// 변경 가능
List list = new ArrayList(Arrays.asList(1,2,3,4,5)); // 새로운 Arraylist

 

 

 

최종 정리 코드를 살펴보며

오늘의 내용을 정리하자.

import java.util.Arrays;

public class Ex11_6 {
    public static void main(String[] args) {
        int[] arr = {0,1,2,3,4};
        int[][] arr2D = {{11,12,13}, {21,22,23}};

        System.out.println("arr=" + Arrays.toString(arr));
//        System.out.println("arr=" + Arrays.toString(arr2D));
        System.out.println("arr2D = " + Arrays.deepToString(arr2D));

        int[] arr2 = Arrays.copyOf(arr, 5);
        int[] arr3 = Arrays.copyOf(arr, 3);
        int[] arr4 = Arrays.copyOf(arr, 7);
        int[] arr5 = Arrays.copyOfRange(arr, 2,4);
        int[] arr6 = Arrays.copyOfRange(arr, 0,7);

        System.out.println("arr2 = " + Arrays.toString(arr2));
        System.out.println("arr3 = " + Arrays.toString(arr3));
        System.out.println("arr4 = " + Arrays.toString(arr4));
        System.out.println("arr5 = " + Arrays.toString(arr5));
        System.out.println("arr6 = " + Arrays.toString(arr6));

        int[] arr7 = new int[5];
        Arrays.fill(arr7, 9); // arr=[9,9,9,9,9]
        System.out.println("arr7=" + Arrays.toString(arr7));

        Arrays.setAll(arr7, i -> (int)(Math.random()*6)+1);
        System.out.println("arr7="+Arrays.toString(arr7));

        for(int i : arr7) {
            char[] graph = new char[i];
            Arrays.fill(graph, '*');
            System.out.println(new String(graph)+i);
        }

        String[][] str2D = new String[][]{{"aaa","bbb"},{"AAA","BBB"}};
        String[][] str2D2 = new String[][]{{"aaa","bbb"},{"AAA","BBB"}};

        System.out.println(Arrays.equals(str2D, str2D2));
        System.out.println(Arrays.deepEquals(str2D, str2D2));

        char[] chArr = {'A','D','C','B','E'};
        System.out.println("chArr=" + Arrays.toString(chArr));
        System.out.println("index of B = " + Arrays.binarySearch(chArr, 'B'));
        System.out.println("= After sorting =");
        Arrays.sort(chArr);
        System.out.println("chArr=" + Arrays.toString(chArr));
        System.out.println("index of B = " + Arrays.binarySearch(chArr, 'B'));
    }
}

 

 


 

 

반응형