Se desea crear una lista circular con números perfectos utilizando hilos
package prylistascircular;
/**
*
* @author laboratorio
*/
public class Nodo {
private int dato;
private Nodo anterior;
private Nodo siguiente;
public Nodo(int dato, Nodo anterior, Nodo siguiente) {
this.dato = dato;
this.anterior = anterior;
this.siguiente = siguiente;
}
public int getDato() {
return dato;
}
public void setDato(int dato) {
this.dato = dato;
}
public Nodo getAnterior() {
return anterior;
}
public void setAnterior(Nodo anterior) {
this.anterior = anterior;
}
public Nodo getSiguiente() {
return siguiente;
}
public void setSiguiente(Nodo siguiente) {
this.siguiente = siguiente;
}
}
package prylistascircular;
/**
*
* @author laboratorio
*/
public class Circular {
private Nodo inicio;
private Nodo fin;
public Circular() {
inicio = fin = null;
}
public boolean esVacia() {
return inicio == null && fin == null;
}
public void insertarInicio(int dato) {
Nodo nuevo = new Nodo(dato, fin, inicio);
if (esVacia()) {
inicio = fin = nuevo;
} else {
inicio.setAnterior(nuevo);
fin.setSiguiente(nuevo);
inicio = nuevo;
}
}
public void insertarFin(int dato) {
Nodo nuevo = new Nodo(dato, fin, inicio);
if (esVacia()) {
inicio = fin = nuevo;
} else {
inicio.setAnterior(nuevo);
fin.setSiguiente(nuevo);
fin = nuevo;
}
}
public void imprimir() {
Nodo aux = inicio;
do {
System.out.println(aux.getDato());
aux = aux.getSiguiente();
} while (aux != inicio);
}
}
package prylistascircular;
/**
*
* @author laboratorio
*/
public class Hilo implements Runnable {
private Circular lista;
private int min;
private int max;
public Hilo(Circular lista, int min, int max) {
this.lista = lista;
this.min = min;
this.max = max;
}
@Override
public void run() {
for (int i = min; i < max; i++) {
int acum = 0;
for (int j = 1; j <= i / 2; j++) {
if (i % j == 0) {
acum += j;
}
}
if (acum == i) {
lista.insertarFin(i);
System.out.println("Inserto; " + i);
}
}
}
}
package prylistascircular;
/**
*
* @author laboratorio
*/
public class PryListasCircular {
/**
* @param args the command line arguments
*/
public static void main(String[] args) throws InterruptedException {
// TODO code application logic here
Circular lista = new Circular();
Hilo h1 = new Hilo(lista, 1, 1000);
h1.run();
Hilo h2 = new Hilo(lista, 8000, 9000);
h2.run();
Hilo h3 = new Hilo(lista, 33550030, 33551000);
h3.run();
h1.join();
h2.join();
h3.join();
lista.imprimir();
}
}
No hay comentarios:
Publicar un comentario