>Java >java지도 시간 >Java에서 배열 슬라이싱 방법은 무엇입니까?

Java에서 배열 슬라이싱 방법은 무엇입니까?

王林
王林앞으로
2023-05-20 18:22:193163검색

1. 질문

배열 슬라이싱은 주어진 배열의 하위 배열을 얻는 방법입니다. a[]가 배열이라고 가정합니다. a[0]부터 a[7]

int a[] = {8, 9, 4, 6, 0, 11, 45, 21}int a[] = {8, 9, 4, 6, 0, 11, 45, 21}

我们需要找到数组索引的一个子集,范围为从 a[3] 到 a[6]。startIndex 对应于 a[3],而 endIndex 对应于 a[6]。因此,我们得到以下切片

a[] = {6, 0, 11, 45}

有以下三种方法可以找到数组的切片:

  1. 通过复制元素

  2. 通过使用 copyOfRange() 方法

  3. 使用 Java 8 流

2.方法

1)通过复制元素

  • 首先,我们找到给定数组的开始和结束索引。

  • 之后,我们创建一个大小为 (endIndex - startIndex) 的空数组(切片数组)。

  • 从给定的数组中,将元素(从 startIndex)复制到切片数组。最后,打印切片数组。

public class Test {
    public static void main(String[] args) {
        int[] array = {0,1,2,3,4,5,6,7,8,9};
        int startIndex = 3, endIndex = 8;
        int[] slicedArray = getSlice(array, startIndex, endIndex + 1);
        System.out.println("Slice of Array: "+ Arrays.toString(slicedArray));
    }
    public static int[] getSlice(int[] array, int startIndex, int endIndex)
    {
        int[] slicedArray = new int[endIndex - startIndex];
        //将数组元素从原始数组复制到新创建的切片数组
        for (int i = 0; i < slicedArray.length; i++)
        {
            slicedArray[i] = array[startIndex + i];
        }
        return slicedArray;
    }
}

结果如下:

Slice of Array: [3, 4, 5, 6, 7, 8]

2)通过使用 copyOfRange() 方法

  • copyOfRange() 方法属于 Java Arrays 类。

  • 它将数组的指定范围复制到新创建的数组(切片数组)中,并从原始数组返回包含指定范围的新创建的数组。

  • 创建数组切片需要 O(n) 时间,存储元素需要 O(n) 空间,其中 n 是结果数组的元素数。

public static int[] copyOfRange(int[] original, int from, int to)

它抛出以下异常:

  • ArrayIndexOutOfBoundsException:如果 from 小于 0 或者 from 大于指定数组的长度。

  • IllegalArgumentException:如果参数 from 大于 to。

  • NullPointerException

    까지 색인이 지정된 8개의 요소가 있습니다. a[3]에서 a[6]까지의 배열 인덱스 하위 집합을 찾아야 합니다. startIndex는 a[3]에 해당하고 endIndex는 a[6]에 해당합니다. 따라서 우리는 다음 슬라이스를 얻습니다.
a[] = {6, 0, 11, 45}

배열의 슬라이스를 찾는 세 가지 방법이 있습니다:

    요소 복사

    • copyOfRange() 메소드 사용

    • Java 8 스트림 사용

    • 2. 메소드

      1) 요소

    • 먼저, 주어진 배열의 시작 및 끝 인덱스를 찾습니다.

    • 그런 다음 (endIndex - startIndex) 크기의 빈 배열(슬라이스 배열)을 만듭니다.

    주어진 배열의 요소(startIndex에서)를 슬라이스 배열로 복사합니다. 마지막으로 슬라이스 배열을 인쇄합니다.

    🎜
    public class Test {
        public static void main(String[] args) {
            int[] array = {0,1,2,3,4,5,6,7,8,9};
            int startIndex = 3, endIndex = 8;
            int[] slicedArray = getSlice(array, startIndex, endIndex + 1);
            System.out.println("Slice of Array: "+ Arrays.toString(slicedArray));
        }
        public static int[] getSlice(int[] array, int startIndex, int endIndex)
        {
            int[] slicedArray = Arrays.copyOfRange(array, startIndex, endIndex);
            return slicedArray;
        }
    }
    🎜결과는 다음과 같습니다. 🎜
    Slice of Array: [3, 4, 5, 6, 7, 8]

    2) copyOfRange() 메소드를 사용하여

    🎜🎜🎜copyOfRange() 메소드는 Java에 속합니다 배열 클래스 . 🎜🎜🎜🎜지정된 배열 범위를 새로 생성된 배열(슬라이스 배열)로 복사하고 원래 배열에서 지정된 범위를 포함하는 새로 생성된 배열을 반환합니다. 🎜🎜🎜🎜배열 슬라이스를 생성하는 데는 O(n) 시간이 걸리고 요소를 저장하려면 O(n) 공간이 필요합니다. 여기서 n은 결과 배열의 요소 수입니다. 🎜🎜🎜
    public class Test {
        public static void main(String[] args) {
            int[] array = {0,1,2,3,4,5,6,7,8,9};
            int startIndex = 3, endIndex = 8;
            int[] slicedArray = getSlice(array, startIndex, endIndex + 1);
            System.out.println("Slice of Array: "+ Arrays.toString(slicedArray));
        }
        public static int[] getSlice(int[] array, int startIndex, int endIndex)
        {
            //获取数组的切片并将其存储在数组 slcarray[] 中
            // range() 方法将元素转换为流
            // 使用 lambda 表达式获取 int 流的元素
            // 使用 toArray() 方法将映射元素转换为切片数组
            int[] slcarray = IntStream.range(startIndex, endIndex).map(i -> array[i]).toArray();
            return slcarray;
        }
    }
    🎜다음 예외가 발생합니다. 🎜🎜🎜🎜ArrayIndexOutOfBoundsException: from이 0보다 작거나 from이 지정된 배열의 길이보다 큰 경우. 🎜🎜🎜🎜IllegalArgumentException: from 매개변수가 to보다 큰 경우. 🎜🎜🎜🎜NullPointerException: 주어진 배열이 비어 있는 경우. 🎜🎜🎜
    Slice of Array: [3, 4, 5, 6, 7, 8]
    🎜결과는 다음과 같습니다. 🎜rrreee🎜3) Java 8 Stream 사용 🎜🎜다음 단계를 사용하여 🎜🎜🎜🎜 Java 8 Stream을 사용하여 배열의 조각을 찾을 수 있습니다. 🎜🎜🎜🎜먼저 startIndex 및 endIndex 배열을 찾습니다. 🎜🎜🎜🎜range() 메서드를 사용하여 (범위 내) 요소를 원래 스트림으로 변환합니다. 🎜🎜🎜🎜 지정된 배열의 지정된 요소를 매핑하려면 map() 메서드를 사용하세요. 🎜🎜🎜🎜toArray() 메서드를 호출하여 매핑된 배열을 배열로 변환합니다. 슬라이스를 인쇄하세요🎜🎜🎜rrreee🎜결과는 다음과 같습니다.🎜rrreee

    위 내용은 Java에서 배열 슬라이싱 방법은 무엇입니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

    성명:
    이 기사는 yisu.com에서 복제됩니다. 침해가 있는 경우 admin@php.cn으로 문의하시기 바랍니다. 삭제