En Java, ¿cómo mover todos los 0 al final de la matriz conservando el orden de una matriz? [2 maneras]
Publicado: 2020-12-31![En Java, ¿cómo mover todos los 0 al final de la matriz conservando el orden de una matriz? [2 maneras]](/uploads/article/578/Jg7tpgI3lsELLLkN.png)
He estado jugando con el problema de moving all 0's to end
de Arrays en diferentes entrevistas en varias combinaciones. A veces pido mover todos los 0 al frente de la matriz, ordenando una matriz sin ninguna estructura de datos, etc.
En este tutorial, repasaremos un ejemplo simple de mover todos los 0 para conservar el orden de un Array. Hay dos enfoques.
Enfoque-1)
QuickSort Lógica de partición. ¿Qué es el punto de pivote?
-
Pivot point
es un elemento clave en el algoritmo de clasificación rápida. Realiza y divide la colección en torno al punto de pivote. - Organiza un Array con elementos más grandes que el pivote antes de él, y elementos más grandes que el pivote después de él.
- Continúe a través del ciclo para ordenar una matriz
La lógica es muy simple:
- Iterar a través de un Array.
- Si array[i] no es igual a 0, cámbielo por el índice actual.
- Si array[i] == 0, simplemente omita el ciclo
- En nuestro caso,
0 is a Pivot point
. - Cada vez que encontramos 0, el contrapivote se incrementará y el elemento se moverá antes del punto de pivote.
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 |
private static void approach1 ( int [ ] crunchifyData ) { // Move 0 to end of array int j = 0 ; for ( int i = 0 ; i < crunchifyData . length ; i ++ ) { if ( crunchifyData [ i ] ! = 0 ) { int temp = crunchifyData [ j ] ; crunchifyData [ j ] = crunchifyData [ i ] ; crunchifyData [ i ] = temp ; j ++ ; } } log ( "\n\nApproach-1 Result: " + Arrays . toString ( crunchifyData ) ) ; } |
Enfoque-2)
- Crear una nueva matriz con el mismo tamaño
- Iterar a través de una matriz y omitir agregar 0
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 |
private static void approach2 ( int [ ] crunchifyData ) { int [ ] num = new int [ crunchifyData . length ] ; int j = 0 ; for ( int i = 0 ; i < crunchifyData . length ; i ++ ) { if ( crunchifyData [ i ] ! = 0 ) { num [ i - j ] = crunchifyData [ i ] ; } else { j ++ ; } } System . out . print ( "\n\nApproach-2 Result: " + Arrays . toString ( num ) ) ; } |
Aquí hay un programa completo:
CrunchifyMoveAll0ToEnd.java
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 |
package crunchify . com . java . tutorials ; import java . util . Arrays ; /** * @author Crunchify.com * Requirement: Move all 0's to end of array preserving order * Input array: 8 8 3 0 4 0 6 0 9 1 * Output array: 8 8 3 4 6 9 1 0 0 0 */ public class CrunchifyMoveAll0ToEnd { public static void main ( String [ ] args ) { int [ ] crunchifyData ; crunchifyData = new int [ ] { 8 , 8 , 3 , 0 , 4 , 0 , 6 , 0 , 9 , 1 } ; log ( "Original array: " + Arrays . toString ( crunchifyData ) ) ; if ( crunchifyData == null | | crunchifyData . length == 0 ) { log ( "Empty Array" ) ; } approach1 ( crunchifyData ) ; approach2 ( crunchifyData ) ; } private static void approach1 ( int [ ] crunchifyData ) { // Move 0 to end of array int j = 0 ; for ( int i = 0 ; i < crunchifyData . length ; i ++ ) { if ( crunchifyData [ i ] ! = 0 ) { int temp = crunchifyData [ j ] ; crunchifyData [ j ] = crunchifyData [ i ] ; crunchifyData [ i ] = temp ; j ++ ; } } log ( "\n\nApproach-1 Result: " + Arrays . toString ( crunchifyData ) ) ; } // Create a new array with same size // Iterate through an Array and skip adding 0 private static void approach2 ( int [ ] crunchifyData ) { int [ ] num = new int [ crunchifyData . length ] ; int j = 0 ; for ( int i = 0 ; i < crunchifyData . length ; i ++ ) { if ( crunchifyData [ i ] ! = 0 ) { num [ i - j ] = crunchifyData [ i ] ; } else { j ++ ; } } System . out . print ( "\n\nApproach-2 Result: " + Arrays . toString ( num ) ) ; } private static void log ( String string ) { System . out . print ( string + " " ) ; } } |
Salida de la consola de Eclipse:
1 2 3 4 5 6 |
Original array : [ 8 , 8 , 3 , 0 , 4 , 0 , 6 , 0 , 9 , 1 ] Approach - 1 Result : [ 8 , 8 , 3 , 4 , 6 , 9 , 1 , 0 , 0 , 0 ] Approach - 2 Result : [ 8 , 8 , 3 , 4 , 6 , 9 , 1 , 0 , 0 , 0 ] Process finished with exit code 0 |
Avíseme si conoce una mejor manera de resolver este problema. Me encantaría escuchar tus pensamientos.
