Código de Java - Array simple dinámico

sin imagen de perfil
Val: 28
Ha aumentado su posición en 120 puestos en Java (en relación al último mes)
Gráfica de Java
Actualizado

Array simple dinámicográfica de visualizaciones


Java

estrellaestrellaestrellaestrellaestrella(6)
Actualizado el 18 de Agosto del 2019 por Daniel (Publicado el 7 de Agosto del 2019)
565 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
347 visualizaciones desde el 7 de Agosto del 2019

3.0
estrellaestrellaestrellaestrellaestrella(1)

Actualizado el 15 de Agosto del 2019 (Publicado el 14 de Agosto del 2019)gráfica de visualizaciones de la versión: 3.0
174 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
44 visualizaciones desde el 18 de Agosto del 2019
estrellaestrellaestrellaestrellaestrella
estrellaestrellaestrellaestrella
estrellaestrellaestrella
estrellaestrella
estrella

Agrego la versión con las modificaciones hechas. Espero que os sirva.
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
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
package v22;
 
/**
 * 
 * @author Daniel
 *
 * @param <T>
 */
public class DynamicArray<T> {
	Object[] vector;
 
	public DynamicArray() {
		vector = new Object[0];
	}
 
	public int tamaño() {
		return vector.length;
	}
 
	// Devuelve el valor con indice como parametro
	public T obtener(int índice) {
		final T t = (T) vector[índice];
		return t;
	}
	// Redimensiona el array
 
	public void agregar(T item) {
		Object aux[] = new Object[vector.length + 1];
		for (int x = 0; x < vector.length; x++) {
			aux[x] = vector[x];
		}
		aux[vector.length] = item;
		vector = aux;
	}
 
// Borra en una posición indicada y redimensiona el array
	public void borrar(int posicion) {
		if (posicion < 0 || posicion >= vector.length)
			throw new ArrayIndexOutOfBoundsException("Has sobrepasado los límites del array");
 
		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;
 
	}
 
}
 
//Prueba
package v22;
 
/**
 * 
 * @author Daniel
 *
 */
public class Prueba {
	DynamicArray<Integer> a = new DynamicArray<Integer>();
 
	public static void main(String[] args) {
 
		new Prueba();
 
	}
 
	public Prueba() {
		pruebaAgregar();
		mostrarItems();
		System.out.println("borrando...");
		pruebaExcepcion();
		borrar();
	}
 
	// Añadimos en el array
	void pruebaAgregar() {
 
		for (int i = 0; i < 10; i++) {
			a.agregar(i);
		}
	}
 
	// Mostramos el contenido del array
	void mostrarItems() {
 
		for (int i = 0; i < a.tamaño(); i++) {
			System.out.println("Dentro: " + a.obtener(i));
		}
	}
 
	// Borramos indicando el indice y el tamaño tras borrar
	void borrar() {
		for (int i = a.tamaño() - 1; i >= 0; i--) {
			a.borrar(i);
			System.out.println("Se ha borrado el indice: " + i + ", el tamaño del array es: " + a.tamaño());
 
		}
 
	}
 
	// Capturamos la excepcion ya que sale de los límites
	void pruebaExcepcion() {
 
		try {
			Thread.sleep(100);
			a.borrar(99);
 
		} catch (ArrayIndexOutOfBoundsException | InterruptedException e) {
			System.err.println(e.getMessage());
		}
	}
}



Comentarios sobre la versión: 4.0 (0)


No hay comentarios
 

Comentar la versión: 4.0

Nombre
Correo (no se visualiza en la web)
Valoración
Comentarios
Es necesario revisar y aceptar las políticas de privacidad

http://lwp-l.com/s5466
Revisar política de publicidad