logo

Matriz dinámica en Java

Una matriz es de tamaño fijo, homogénea. estructura de datos . La limitación de las matrices es que tienen un tamaño fijo. Significa que debemos especificar la cantidad de elementos al declarar la matriz. Aquí surge una pregunta: ¿Qué pasa si queremos insertar un elemento y no queda más espacio para el nuevo elemento? Aquí, el concepto de matriz dinámica llega a existir. Gasta el tamaño de la matriz dinámicamente.

En esta sección entenderemos qué es una matriz dinámica, características de la matriz dinámica, cómo cambiar el tamaño de una matriz dinámica, y cómo implementar una matriz dinámica en Java .

¿Qué es una matriz dinámica?

La matriz dinámica es una tamaño variable estructura de datos de la lista. Crece automáticamente cuando intentamos insertar un elemento si no queda más espacio para el nuevo elemento. Nos permite añadir y quitar elementos. Asigna memoria en tiempo de ejecución utilizando el montón. Puede cambiar su tamaño durante el tiempo de ejecución.

En Java , Lista de arreglo es una implementación redimensionable. Implementa la interfaz List y proporciona todos los métodos relacionados con las operaciones de la lista. La fuerza de la matriz dinámica es:

  • búsqueda rápida
  • tamaño variable
  • Compatible con caché

Trabajo de matriz dinámica

En la matriz dinámica, los elementos se almacenan de forma contigua desde el inicio de la matriz y el espacio restante no se utiliza. Podemos ir añadiendo los elementos hasta consumir por completo el espacio reservado. Cuando se consume el espacio reservado y es necesario agregar algunos elementos. En tal caso, es necesario aumentar el tamaño de la matriz de tamaño fijo. Tenga en cuenta que antes de agregar el elemento, asignamos una matriz más grande, copiamos los elementos de la matriz y devolvemos la matriz recién creada.

Otra forma de agregar un elemento es primero crear una función que cree una nueva matriz de tamaño doble, copie todos los elementos de la matriz anterior y devuelva la nueva matriz. De manera similar, también podemos reducir el tamaño de la matriz dinámica.

Tamaño versus capacidad

La inicialización de una matriz dinámica crea una matriz de tamaño fijo. En la siguiente figura, la implementación de la matriz tiene 10 índices. Hemos agregado cinco elementos a la matriz. Ahora, la matriz subyacente tiene una longitud de cinco. Por lo tanto, la longitud del tamaño de la matriz dinámica es 5 y su capacidad es 10. La matriz dinámica realiza un seguimiento del punto final.

Matriz dinámica en Java

Características de la matriz dinámica

En Java, la matriz dinámica tiene tres características clave: Agregue un elemento, elimine un elemento y cambie el tamaño de una matriz.

Agregar elemento en una matriz dinámica

En la matriz dinámica, podemos crear una matriz de tamaño fijo si necesitamos agregar algunos elementos más a la matriz. Normalmente, crea una nueva matriz de doble tamaño. Después de eso, copia todos los elementos a la matriz recién creada. Utilizamos el siguiente enfoque:

Matriz dinámica en Java

Eliminar un elemento de una matriz dinámica

Si queremos eliminar un elemento de la matriz en el índice especificado, usamos el eliminar en (i) método. El método analiza el número de índice de ese elemento que queremos eliminar. Después de eliminar el elemento, desplaza los elementos restantes (elementos que están a la derecha del elemento eliminado) hacia la izquierda desde el número de índice especificado. También usamos el método remove() que elimina un elemento del final de la matriz. Después de mover los elementos, almacena 0 en el palacio del último elemento. Entendámoslo a través de un ejemplo, como hemos mostrado en la siguiente figura.

Matriz dinámica en Java

Cambiar el tamaño de una matriz dinámica en Java

Necesitamos cambiar el tamaño de una matriz en dos escenarios si:

  • La matriz utiliza más memoria de la necesaria.
  • La matriz ocupa toda la memoria y necesitamos agregar elementos.

En el primer caso utilizamos el tamaño de reducción() método para cambiar el tamaño del formación . Reduce el tamaño de la matriz. Libera la memoria extra o no utilizada. En el segundo caso utilizamos el crecerTamaño() método para cambiar el tamaño de la matriz. Aumenta el tamaño de la matriz.

Es una operación costosa porque requiere una matriz más grande y copia todos los elementos de la matriz anterior y luego devuelve la nueva matriz.

Matriz dinámica en Java

Supongamos que en la matriz anterior se requiere agregar seis elementos más y, en la matriz, no queda más memoria para almacenar elementos. En tales casos, hacemos crecer la matriz usando el crecerTamaño() método.

Matriz dinámica en Java

Inicializar una matriz dinámica

La inicialización de la matriz dinámica es la misma que la de la matriz estática. Considere el siguiente programa Java que inicializa una matriz dinámica.

InitializeDynamicArray.java

 public class InitializeDynamicArray { public static void main(String[] args) { //declaring array int array[]; //initialize an array array= new int[6]; //adding elements to the array array[0] = 34; array[1] = 90; array[2] = 12; array[3] = 22; array[4] = 9; array[5] = 27; System.out.print(&apos;Elements of Array are: &apos;); //iteraton over the array for(int i=0; i <array.length ; i++) { system.out.print(array[i] +' '); } < pre> <p> <strong>Output:</strong> </p> <pre> Elements of Array are: 34 90 12 22 9 27 </pre> <p>Let&apos;s implement the operations in a Java program that we have discussed above.</p> <p> <strong>DynamicArrayExample1.java</strong> </p> <pre> public class DynamicArrayExample1 { private int array[]; private int count; private int sizeofarray; //creating a constructor of the class that initializes the values public DynamicArrayExample1() { array = new int[1]; count = 0; sizeofarray = 1; } //creating a function that appends an element at the end of the array public void addElement(int a) { //compares if the number of elements is equal to the size of the array or not if (count == sizeofarray) { //invoking the growSize() method that creates an array of double size growSize(); } //appens an element at the end of the array array[count] = a; count++; } //function that creates an array of double size public void growSize() { //declares a temp[] array int temp[] = null; if (count == sizeofarray) { //initialize a double size array of array temp = new int[sizeofarray * 2]; { for (int i = 0; i <sizeofarray; i++) { copies all the elements of old array temp[i]="array[i];" } sizeofarray="sizeofarray" * 2; creating a function that deletes an element at specified index public void addelementat(int index, int a) compare size with number if not equal grows (count="=" sizeofarray) invoking growsize() method growsize(); for (int i="count" - 1;>= index; i--) { //shifting all the elements to the left from the specified index array[i + 1] = array[i]; } //inserts an element at the specified index array[index] = a; count++; } public static void main(String[] args) { DynamicArrayExample1 da = new DynamicArrayExample1(); //adding elements to the array da.addElement(12); da.addElement(22); da.addElement(35); da.addElement(47); da.addElement(85); da.addElement(26); da.addElement(70); da.addElement(81); da.addElement(96); da.addElement(54); System.out.println(&apos;Elements of the array:&apos;); //iterate over the array for accessing the elements for (int i = 0; i <da.sizeofarray; 5 99 i++) { system.out.print(da.array[i] + ' '); } system.out.println(); determines and prints the size number of elements array system.out.println('size array: da.sizeofarray); system.out.println('no. in da.count); invoking method to add an element at specified index da.addelementat(5, 99); where is be system.out.println('
elements after adding 5:'); iterate over for accessing (int i="0;" < da.sizeofarray; pre> <p> <strong>Output:</strong> </p> <img src="//techcodeview.com/img/java-tutorial/02/dynamic-array-java-6.webp" alt="Dynamic Array in Java"> <p>Let&apos;s shrink the array, delete the last element, and a specified element from the array.</p> <p> <strong>DynamicArrayExample2.java</strong> </p> <pre> public class DynamicArrayExample2 { private int array[]; private int count; private int sizeofarray; //creating a constructor of the class that initializes the values public DynamicArrayExample2() { array = new int[1]; count = 0; sizeofarray = 1; } //creating a function that appends an element at the end of the array public void addElement(int a) { //compares if the number of elements is equal to the size of the array or not if (count == sizeofarray) { //invoking the growSize() method that creates an array of double size growSize(); } //appens an element at the end of the array array[count] = a; count++; } //function that creates an array of double size public void growSize() { //declares a temp[] array int temp[] = null; if (count == sizeofarray) { //initialize a double size array of array temp = new int[sizeofarray * 2]; { for (int i = 0; i <sizeofarray; i++) { copies all the elements of old array temp[i]="array[i];" } sizeofarray="sizeofarray" * 2; method removes unused space public void shrinksize() declares a temp[] int if (count> 0) { //creates an array of the size equal to the count i.e. number of elements the array have temp = new int[count]; for (int i = 0; i <count; i++) { copies all the elements of old array temp[i]="array[i];" } sizeofarray="count;" creating a function that removes last for public void removeelement() if (count> 0) { array[count - 1] = 0; count--; } } //creating a function that delets an element from the specified index public void removeElementAt(int index) { if (count &gt; 0) { for (int i = index; i <count 7 - 1; i++) { shifting all the elements to left from specified index array[i]="array[i" + 1]; } array[count 1]="0;" count--; public static void main(string[] args) dynamicarrayexample2 da="new" dynamicarrayexample2(); adding array da.addelement(12); da.addelement(22); da.addelement(35); da.addelement(47); da.addelement(85); da.addelement(26); da.addelement(70); da.addelement(81); da.addelement(96); da.addelement(54); system.out.println('elements of array:'); iterate over for accessing (int i="0;" < da.sizeofarray; system.out.print(da.array[i] ' '); system.out.println(); determines and prints size number system.out.println('size array: da.sizeofarray); system.out.println('no. in da.count); invoking method delete last element da.removeelement(); after deleting system.out.print('
elements element: system.out.print('no. da.count+'
'); that deletes an da.removeelementat(7); at 7: pre> <p> <strong>Output:</strong> </p> <img src="//techcodeview.com/img/java-tutorial/02/dynamic-array-java-7.webp" alt="Dynamic Array in Java"> <hr></count></count;></sizeofarray;></pre></da.sizeofarray;></sizeofarray;></pre></array.length>

Implementemos las operaciones en un programa Java que hemos discutido anteriormente.

DynamicArrayExample1.java

 public class DynamicArrayExample1 { private int array[]; private int count; private int sizeofarray; //creating a constructor of the class that initializes the values public DynamicArrayExample1() { array = new int[1]; count = 0; sizeofarray = 1; } //creating a function that appends an element at the end of the array public void addElement(int a) { //compares if the number of elements is equal to the size of the array or not if (count == sizeofarray) { //invoking the growSize() method that creates an array of double size growSize(); } //appens an element at the end of the array array[count] = a; count++; } //function that creates an array of double size public void growSize() { //declares a temp[] array int temp[] = null; if (count == sizeofarray) { //initialize a double size array of array temp = new int[sizeofarray * 2]; { for (int i = 0; i <sizeofarray; i++) { copies all the elements of old array temp[i]="array[i];" } sizeofarray="sizeofarray" * 2; creating a function that deletes an element at specified index public void addelementat(int index, int a) compare size with number if not equal grows (count="=" sizeofarray) invoking growsize() method growsize(); for (int i="count" - 1;>= index; i--) { //shifting all the elements to the left from the specified index array[i + 1] = array[i]; } //inserts an element at the specified index array[index] = a; count++; } public static void main(String[] args) { DynamicArrayExample1 da = new DynamicArrayExample1(); //adding elements to the array da.addElement(12); da.addElement(22); da.addElement(35); da.addElement(47); da.addElement(85); da.addElement(26); da.addElement(70); da.addElement(81); da.addElement(96); da.addElement(54); System.out.println(&apos;Elements of the array:&apos;); //iterate over the array for accessing the elements for (int i = 0; i <da.sizeofarray; 5 99 i++) { system.out.print(da.array[i] + \' \'); } system.out.println(); determines and prints the size number of elements array system.out.println(\'size array: da.sizeofarray); system.out.println(\'no. in da.count); invoking method to add an element at specified index da.addelementat(5, 99); where is be system.out.println(\'
elements after adding 5:\'); iterate over for accessing (int i="0;" < da.sizeofarray; pre> <p> <strong>Output:</strong> </p> <img src="//techcodeview.com/img/java-tutorial/02/dynamic-array-java-6.webp" alt="Dynamic Array in Java"> <p>Let&apos;s shrink the array, delete the last element, and a specified element from the array.</p> <p> <strong>DynamicArrayExample2.java</strong> </p> <pre> public class DynamicArrayExample2 { private int array[]; private int count; private int sizeofarray; //creating a constructor of the class that initializes the values public DynamicArrayExample2() { array = new int[1]; count = 0; sizeofarray = 1; } //creating a function that appends an element at the end of the array public void addElement(int a) { //compares if the number of elements is equal to the size of the array or not if (count == sizeofarray) { //invoking the growSize() method that creates an array of double size growSize(); } //appens an element at the end of the array array[count] = a; count++; } //function that creates an array of double size public void growSize() { //declares a temp[] array int temp[] = null; if (count == sizeofarray) { //initialize a double size array of array temp = new int[sizeofarray * 2]; { for (int i = 0; i <sizeofarray; i++) { copies all the elements of old array temp[i]="array[i];" } sizeofarray="sizeofarray" * 2; method removes unused space public void shrinksize() declares a temp[] int if (count> 0) { //creates an array of the size equal to the count i.e. number of elements the array have temp = new int[count]; for (int i = 0; i <count; i++) { copies all the elements of old array temp[i]="array[i];" } sizeofarray="count;" creating a function that removes last for public void removeelement() if (count> 0) { array[count - 1] = 0; count--; } } //creating a function that delets an element from the specified index public void removeElementAt(int index) { if (count &gt; 0) { for (int i = index; i <count 7 - 1; i++) { shifting all the elements to left from specified index array[i]="array[i" + 1]; } array[count 1]="0;" count--; public static void main(string[] args) dynamicarrayexample2 da="new" dynamicarrayexample2(); adding array da.addelement(12); da.addelement(22); da.addelement(35); da.addelement(47); da.addelement(85); da.addelement(26); da.addelement(70); da.addelement(81); da.addelement(96); da.addelement(54); system.out.println(\'elements of array:\'); iterate over for accessing (int i="0;" < da.sizeofarray; system.out.print(da.array[i] \' \'); system.out.println(); determines and prints size number system.out.println(\'size array: da.sizeofarray); system.out.println(\'no. in da.count); invoking method delete last element da.removeelement(); after deleting system.out.print(\'
elements element: system.out.print(\'no. da.count+\'
\'); that deletes an da.removeelementat(7); at 7: pre> <p> <strong>Output:</strong> </p> <img src="//techcodeview.com/img/java-tutorial/02/dynamic-array-java-7.webp" alt="Dynamic Array in Java"> <hr></count></count;></sizeofarray;></pre></da.sizeofarray;></sizeofarray;>