Código de Java - Array simple dinámico

sin imagen de perfil

Array simple dinámicográfica de visualizaciones


Java

Actualizado el 18 de Agosto del 2019 por Anonymous (3 códigos) (Publicado el 7 de Agosto del 2019)
4.142 visualizaciones desde el 7 de Agosto del 2019
Código fuente muy útil. Permite usar arrays simples de forma dinámica como si fuera un ArrayList pero sin serlo. Puedes probarlo con cualquier wrapper class, aunque yo lo pruebo con Integer.

Requerimientos

El código es probado desde la segunda clase. Puedes usar el código para redimensionar arrays.

2.0
estrellaestrellaestrellaestrellaestrella(5)

Actualizado el 10 de Agosto del 2019 (Publicado el 7 de Agosto del 2019)gráfica de visualizaciones de la versión: 2.0
933 visualizaciones desde el 7 de Agosto del 2019
estrellaestrellaestrellaestrellaestrella
estrellaestrellaestrellaestrella
estrellaestrellaestrella
estrellaestrella
estrella

Código reeditado con los sugerimientos de un comentario sobre mi código anterior. Actualmente el código usa generics. Gracias a esto permitirá elegir el tipo de valor que quieras almacenar. Recordar que para que el código funcione tienes que poner la clase DynamicArray en un archivo y Prueba en otro. Espero que sea útil.
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
71
72
/**
 * 
 * @author Daniel
 *
 * @param <E>
 */
public class DynamicArray<E> {
	Object[] vector;
 
	public DynamicArray() {
		vector = new Object[0];
	}
	//Devuelve el tamaño array
	public int tamaño() {
		return vector.length;
	}
	//Devuelve el valor con ese indice
	public E obtener(int índice) {
		final E e = (E)vector[índice];
		return e ;
	}
	// Redimensiona arrays de String
 
	public void agregar(E frase) {
		Object aux[] = new Object[vector.length + 1];
		for (int x = 0; x < vector.length; x++) {
			aux[x] = vector[x];
		}
		aux[vector.length] = frase;
		vector = aux;
	}
 
// Borra en una posion indicada y redimensiona array de String 
	public void borrar(int posicion) {
		if ((vector.length - 1) != posicion) {
			for (int i = posicion; i < (vector.length - 1); i++) {
				vector[i] = vector[i + 1];
			}
		}
		Object aux[] = new Object[vector.length - 1];
		for (int i = 0; i < aux.length; i++) {
			aux[i] = vector[i];
		}
		vector = aux;
	}
 
}
/**
 * 
 * @author Daniel
 *
 */
public class Prueba {
public static void main(String[] args) {
	DynamicArray<Integer> a = new DynamicArray<Integer>();
	//Añadimos en el array
	for(int i=0;i<10;i++) {
		a.agregar(i);
	}
	//Mostramos lo agregado
	for (int i = 0; i<a.tamaño();i ++) {
		System.out.println("Dentro: "+a.obtener(i));
	}
	//Borramos una posicion
	a.borrar(1);
	System.out.println("borrando...");
	//Mostramos el array redimensionado desues de borrar
	for (int i = 0; i<a.tamaño();i ++) {
		System.out.println("Dentro: "+a.obtener(i));
	}
}
}



Comentarios sobre la versión: 2.0 (5)

Imágen de perfil
8 de Agosto del 2019
estrellaestrellaestrellaestrellaestrella
Pareciera que la clase podria tomar partido del uso de generics y eliminar parte de la redundancia que se produce por tener distintas funciones para distintos tipos.
Responder
8 de Agosto del 2019
estrellaestrellaestrellaestrellaestrella
Puse esas funciones redundantes de forma sobreescrita para que cada uno eligera la que necesitara. :)
Responder
8 de Agosto del 2019
estrellaestrellaestrellaestrellaestrella
En la siguiente versión lo eliminaré. Gracias por tu comentario
Responder
Imágen de perfil
12 de Agosto del 2019
estrellaestrellaestrellaestrellaestrella
Comentarios a la version 2:

Cada elemento al interior del arreglo al interior de la clase, deberia ser de tipo E.
No tiene mucho sentido tener un arreglo de Object, y hacer casts, cuando podrias tener directamente arreglo de E. Alguna razon para tener Object en vez de E?

A proposito, por que le llamas E? Tipicamente el tipo generico lo llaman T.
Parece mas natural decir el tipo T donde aparezca por ahi que tipo E.

Que pasa si en el parametro de borrar te indican un numero negativo, o mas alla de los limites del arreglo?

Algunos comentarios estan obsoletos con el cambio de tipo a generico (aparece Array de String varias veces)
Hay un mispelling en la palabra posicion (dice posion).

Sugiero que no edites encima, sino que mantengas las versiones. Asi van a tener mas sentido los comentarios previos y los que lean tu codigo para aprender, pueden aprender tambien con la evolucion del codigo.
Responder
12 de Agosto del 2019
estrellaestrellaestrellaestrellaestrella
Hola. Aprecio tus comentarios. En cuanto tenga tiempo hago todas las modificaciones. Dejaré, a partir de ahora, los códigos editados y los anteriores, ya los marcaré como versión anterior. Gracias.
Responder

Comentar la versión: 2.0

Nombre
Correo (no se visualiza en la web)
Valoración
Comentarios...
CerrarCerrar
CerrarCerrar
Cerrar

Tienes que ser un usuario registrado para poder insertar imágenes, archivos y/o videos.

Puedes registrarte o validarte desde aquí.

Codigo
Negrita
Subrayado
Tachado
Cursiva
Insertar enlace
Imagen externa
Emoticon
Tabular
Centrar
Titulo
Linea
Disminuir
Aumentar
Vista preliminar
sonreir
dientes
lengua
guiño
enfadado
confundido
llorar
avergonzado
sorprendido
triste
sol
estrella
jarra
camara
taza de cafe
email
beso
bombilla
amor
mal
bien
Es necesario revisar y aceptar las políticas de privacidad

3.0
estrellaestrellaestrellaestrellaestrella(1)

Publicado el 14 de Agosto del 2019gráfica de visualizaciones de la versión: 3.0
1.077 visualizaciones desde el 14 de Agosto del 2019

4.0

Publicado el 18 de Agosto del 2019gráfica de visualizaciones de la versión: 4.0
2.133 visualizaciones desde el 18 de Agosto del 2019
http://lwp-l.com/s5466