알고리즘 체조 7
Move zeros to left
설명
하나의 정수형 배열이 전달됩니다.
배열에서 다른 요소의 순서를 유지하면서 0과 같은 모든 요소를 왼쪽으로 이동시키는 알고리즘을 구현합시다.
다음 정수 배열을 살펴 보겠습니다.
data:image/s3,"s3://crabby-images/1f305/1f305a11eab8cd4ecccb0691db5a47ce1bb8123d" alt=""
모든 0과 같은 요소를 왼쪽으로 이동하면 배열은 다음과 같습니다. (0이 아닌 요소의 순서를 유지해야 함)
data:image/s3,"s3://crabby-images/42a9f/42a9fc98592697c26750de92ff941bad35ad6618" alt=""
Solution
Runtime Complexity O(n)
0 요소를 배열에서 찾아야합니다.
Memory Complexity O(1)
두 개의 포인터 (반복자)를 사용하여 전달 된 배열에서만 구현할 수 있습니다.
알고리즘의 주요 흐름은
data:image/s3,"s3://crabby-images/32943/329434fc3e196a26e75ebfd6213df1bee9a099ba" alt=""
data:image/s3,"s3://crabby-images/03634/03634e5593f4343e18f6679143d6ce7f9b9444aa" alt=""
data:image/s3,"s3://crabby-images/7a657/7a6576887747dedb489769e7fc2a91676ef0ee47" alt=""
read_index가 제로 이외를 가리키는 경우, write_index에 read_index의 요소를 기입해, write_index와 read_index의 양쪽 모두를 감소.
data:image/s3,"s3://crabby-images/b968d/b968dba2e7d1a124066fa4b0bc5e275df7075bb9" alt=""
data:image/s3,"s3://crabby-images/113d9/113d9fe906300c7ea7db8650d1e37e766d671862" alt=""
data:image/s3,"s3://crabby-images/f16ae/f16ae0887f1329086a0e38d42deef6ad0ea2c62d" alt=""
data:image/s3,"s3://crabby-images/c671c/c671c2b34d37a84da2cf0ce266bc628911bd9d59" alt=""
구현
moveZeroToLeft.javapublic class moveZerosToLeft {
public void move_zeros_to_left_in_array(int[] A) {
int readIndex = A.length - 1;
int writeIndex = A.length -1;
while (readIndex >= 0) {
if (A[readIndex] != 0) {
A[writeIndex] = A[readIndex];
writeIndex--;
}
readIndex--;
}
while (writeIndex >= 0) {
A[writeIndex] = 0;
writeIndex--;
}
}
}
Mina.javaimport java.util.Arrays;
public class Main {
public static void main(String[] args) {
// write your code here
moveZerosToLeft algorithm = new moveZerosToLeft();
int[] v = new int[]{1, 10, -1, 11, 5, 0, -7, 0, 25, -35};
System.out.println("Original Array: " + Arrays.toString(v));
algorithm.move_zeros_to_left_in_array(v);
for (int item : v) {
System.out.print(item + ", ");
}
}
}
Output
Reference
이 문제에 관하여(알고리즘 체조 7), 우리는 이곳에서 더 많은 자료를 발견하고 링크를 클릭하여 보았다
https://qiita.com/yutakihara/items/521e6127ff99c5196bce
텍스트를 자유롭게 공유하거나 복사할 수 있습니다.하지만 이 문서의 URL은 참조 URL로 남겨 두십시오.
우수한 개발자 콘텐츠 발견에 전념
(Collection and Share based on the CC Protocol.)
public class moveZerosToLeft {
public void move_zeros_to_left_in_array(int[] A) {
int readIndex = A.length - 1;
int writeIndex = A.length -1;
while (readIndex >= 0) {
if (A[readIndex] != 0) {
A[writeIndex] = A[readIndex];
writeIndex--;
}
readIndex--;
}
while (writeIndex >= 0) {
A[writeIndex] = 0;
writeIndex--;
}
}
}
import java.util.Arrays;
public class Main {
public static void main(String[] args) {
// write your code here
moveZerosToLeft algorithm = new moveZerosToLeft();
int[] v = new int[]{1, 10, -1, 11, 5, 0, -7, 0, 25, -35};
System.out.println("Original Array: " + Arrays.toString(v));
algorithm.move_zeros_to_left_in_array(v);
for (int item : v) {
System.out.print(item + ", ");
}
}
}
Reference
이 문제에 관하여(알고리즘 체조 7), 우리는 이곳에서 더 많은 자료를 발견하고 링크를 클릭하여 보았다 https://qiita.com/yutakihara/items/521e6127ff99c5196bce텍스트를 자유롭게 공유하거나 복사할 수 있습니다.하지만 이 문서의 URL은 참조 URL로 남겨 두십시오.
우수한 개발자 콘텐츠 발견에 전념
(Collection and Share based on the CC Protocol.)