Java에서 배열 이동
-
for
루프 및temp
변수를 사용하여 Java에서 배열 이동 -
skip()
메소드를 사용하여 Java 8에서 배열 이동 -
Collections.rotate(List<type> list, int distance)
를 사용하여 Java에서 배열 이동
이 기사에서는 Java에서 배열 요소를 이동하는 방법을 살펴 봅니다.
for
루프 및temp
변수를 사용하여 Java에서 배열 이동
이 코드에는int
유형 변수의 모음 인array
변수가 있습니다. 여기서 우리는 변수n
에 의해 주어진 인덱스 2에있는 요소를 가져 오려고 시도하고 배열의 인덱스 0으로 이동합니다.
이 목적을 달성하기 위해for
루프로 구성된ShiftToRight
메소드에array
및 인덱스를 전달합니다. 요소를temp
변수의 인덱스n
에 저장합니다.
temp = a[n];
i.e.temp = [ 2 ] i.e.temp = a[2] i.e.temp = 3;
첫 번째 반복 :
for (i = 2; i > 0; i--) i.e.for (i = 2; 2 > 0; i--)
a[i] = a[i - 1];
i.e.a[2] = a[2 - 1] i.e.a[2] = a[1] i.e.a[2] = 2
두 번째 반복 :
for (i = 1; 1 > 0; i--) ```
```java
a[i] = a[i - 1];
i.e.a[1] = a[1 - 1] i.e.a[1] = a[0] i.e.a[1] = 1
i(0)
이 0보다 크지 않기 때문에for
루프에서 나옵니다.
a[0] = temp i.e.a[0] = 3
전달 된 인덱스 값 뒤에 오는array
의 요소는 변경되지 않습니다. 이 경우 마지막 두 요소는 이동 후에도 원래 인덱스에 남아 있습니다.
import java.util.Arrays;
public class ShiftTest {
public static void main(String args[]) {
int[] array = {1, 2, 3, 4, 5};
int n = 2;
System.out.println("Array " + Arrays.toString(array));
ShiftToRight(array, n);
}
public static void ShiftToRight(int a[], int n) {
int temp = a[n];
for (int i = n; i > 0; i--) {
a[i] = a[i - 1];
}
a[0] = temp;
System.out.println("Array after shifting to right by one : " + Arrays.toString(a));
}
}
출력:
Array [1, 2, 3, 4, 5]
Array after shifting to right by one : [3, 1, 2, 4, 5]
skip()
메소드를 사용하여 Java 8에서 배열 이동
Java 8의skip()
메소드는 스트림의n
요소 수를 버리고 나머지 요소로 구성된 스트림을 리턴합니다. 스트림에n
요소 미만이 포함 된 경우 빈 스트림을 리턴합니다.
Arrays.stream()
메서드를 사용하여array
를 스트림으로 변환하고 여기에 1을 전달하는skip()
메서드를 호출합니다. 배열의 첫 번째 요소를 건너 뜁니다. 나중에lambda
형식을 사용하여 반환 된 스트림의 각 요소를 인쇄합니다.
import java.util.Arrays;
public class TestArray {
public static void main(String[] args) {
int[] array = {1, 2, 3, 4, 5, 6, 7};
Arrays.stream(array).skip(1).forEach(System.out::println);
}
}
출력:
ShiftedArray: [2, 3, 4, 5, 6, 7]
Collections.rotate(List<type> list, int distance)
를 사용하여 Java에서 배열 이동
배열을 하나씩 이동하기 위해Collection
목록에 주어진 요소를 주어진 거리만큼 회전시키는이 방법을 사용합니다. Arrays.asList()
를 사용하여 정렬를 목록로 변환합니다. 목록은 인덱스 2에서 회전됩니다.
지정된 거리만큼 목록의 각 요소를 이동하고 지정된 길이보다 긴 인덱스를 가진 요소는 목록의 시작 부분으로 이동합니다.
import java.util.Arrays;
import java.util.Collections import java.util.List;
public class Test11 {
public static void main(String args[]) {
String[] strArray = {"One", "Two", "Three", "Four", "Five"};
System.out.println("Original List : " + Arrays.toString(strArray));
List<String> list = Arrays.asList(strArray);
Collections.rotate(list, 2);
System.out.println("Rotated List: " + list);
}
}
출력:
Original List : [One, Two, Three, Four, Five]
Rotated List: [Four, Five, One, Two, Three]
Rupam Saini is an android developer, who also works sometimes as a web developer., He likes to read books and write about various things.
LinkedIn