배열 슬라이싱은 주어진 배열의 하위 배열을 얻는 방법입니다. 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}
有以下三种方法可以找到数组的切片:
通过复制元素
通过使用 copyOfRange() 方法
使用 Java 8 流
首先,我们找到给定数组的开始和结束索引。
之后,我们创建一个大小为 (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]
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
a[] = {6, 0, 11, 45}
배열의 슬라이스를 찾는 세 가지 방법이 있습니다: 요소 복사
copyOfRange() 메소드 사용
Java 8 스트림 사용
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]
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 중국어 웹사이트의 기타 관련 기사를 참조하세요!