Bugs fixed.

Linked list work.
Non fullscreen.
Comments fixed.
This commit is contained in:
Chris Cromer 2016-06-23 21:31:27 -04:00
parent 073915a3c4
commit 2ea2f91b36
15 changed files with 466 additions and 30 deletions

View File

@ -293,9 +293,9 @@ public class Array {
} }
/** /**
* * Particionar el array desded la izquerda y derecho usando un pivot.
* @param izquerda int: La posición del quick desded la izquerda. * @param izquerda int: La posición del quick desde la izquerda.
* @param derecha int: La posición del quick desded la derecha. * @param derecha int: La posición del quick desde la derecha.
* @param pivot String: El valor a comparar con los otros. * @param pivot String: El valor a comparar con los otros.
* @return ParticionarResult: Los resultados de particionar. * @return ParticionarResult: Los resultados de particionar.
*/ */

View File

@ -217,7 +217,7 @@ public class ArrayController implements Initializable {
if (encontrado != -1) { if (encontrado != -1) {
generarGrafico(); generarGrafico();
grafico = new Grafico(scene); grafico = new Grafico(scene);
grafico.destacer(encontrado, "rectangulo"); grafico.destacer(encontrado, Grafico.RECTANGULO);
} }
else { else {
errorNoEsta(); errorNoEsta();
@ -265,8 +265,10 @@ public class ArrayController implements Initializable {
scene = contenidoArray.getScene(); scene = contenidoArray.getScene();
grafico = new Grafico(scene); grafico = new Grafico(scene);
this.array = new Array(10); this.array = new Array(10);
Array array = (Array) scene.getUserData(); ArrayTipos arrayTipos = (ArrayTipos) scene.getUserData();
this.array.setOrdered(array.isOrdered()); if (arrayTipos.getTipo() == ArrayTipos.ORDENADO) {
this.array.setOrdered(true);
}
} }
/** /**

View File

@ -0,0 +1,45 @@
package cl.cromer.estructuras;
/**
* Esta clase contiene los tipos de array.
*/
final public class ArrayTipos {
/**
* Tipo de array simple.
*/
static final public int SIMPLE = 0;
/**
* Tipo de array ordenado.
*/
static final public int ORDENADO = 1;
/**
* El tipo que está elegido.
*/
private int tipo;
/**
* Inicilizar el tipo.
* @param tipo int: Tipo de array, {@value #SIMPLE} o {@value #ORDENADO}
*/
public ArrayTipos(int tipo) {
switch (tipo) {
case SIMPLE:
this.tipo = SIMPLE;
break;
case ORDENADO:
this.tipo = ORDENADO;
break;
default:
this.tipo = SIMPLE;
}
}
/**
* Devolver el tipo.
* @return int: El tipo de array.
*/
public int getTipo() {
return tipo;
}
}

View File

@ -91,7 +91,7 @@ public class Cola {
* @return String: El valor que está guardado en el indice. * @return String: El valor que está guardado en el indice.
*/ */
public String getIndice(int indice) { public String getIndice(int indice) {
if (indice >= 0 && indice < cola.length) { if (cola != null && indice >= 0 && indice < cola.length) {
return cola[indice]; return cola[indice];
} }
else { else {

View File

@ -192,7 +192,7 @@ public class ColaController implements Initializable {
int encontrado = cola.peek(); int encontrado = cola.peek();
if (encontrado != Integer.MIN_VALUE) { if (encontrado != Integer.MIN_VALUE) {
generarGrafico(); generarGrafico();
grafico.destacer(0, "rectangulo"); grafico.destacer(0, Grafico.RECTANGULO);
} }
else { else {
errorVacia(); errorVacia();

View File

@ -10,7 +10,7 @@ public class Colores {
/** /**
* Cuantos colores estan definidos en esta clase. * Cuantos colores estan definidos en esta clase.
*/ */
static public int MAX_COLORS = 7; static final public int MAX_COLORS = 7;
/** /**
* El color actual en forma numerica. * El color actual en forma numerica.

View File

@ -16,6 +16,16 @@ import javafx.util.Duration;
* @author Chris Cromer * @author Chris Cromer
*/ */
public class Grafico { public class Grafico {
/**
* Tipo de dibujo rectuangular.
*/
static final public int RECTANGULO = 0;
/**
* Tipo de dibujo circular.
*/
static final public int CIRCULO = 1;
/** /**
* Contiene la animación de destacar. * Contiene la animación de destacar.
*/ */
@ -29,7 +39,7 @@ public class Grafico {
/** /**
* El tipo de objeto que está destacado. * El tipo de objeto que está destacado.
*/ */
private String tipo; private int tipo;
/** /**
* El color original de fondo para volver cuando no es destacado. * El color original de fondo para volver cuando no es destacado.
@ -138,22 +148,25 @@ public class Grafico {
/** /**
* Destacar un elemento * Destacar un elemento
* @param valor int: El indice a destacar. * @param valor int: El indice a destacar.
* @param tipo String: El tipo de objeto a destacer(rectangulo o cicurlo) * @param tipo int: El tipo de objeto a destacer, {@value #RECTANGULO} o {@value #CIRCULO}
*/ */
public void destacer(int valor, String tipo) { public void destacer(int valor, int tipo) {
if (!tipo.equals("rectangulo") && !tipo.equals("circulo")) { if (tipo != RECTANGULO && tipo != CIRCULO) {
return; return;
} }
this.tipo = tipo; else {
this.tipo = tipo;
}
destacado = valor; destacado = valor;
Colores colores = new Colores(); Colores colores = new Colores();
Rectangle rectangle = null; Rectangle rectangle = null;
Circle circle = null; Circle circle = null;
if (tipo.equals("rectangulo")) { if (this.tipo == RECTANGULO) {
rectangle = (Rectangle) scene.lookup("#border_" + String.valueOf(valor)); rectangle = (Rectangle) scene.lookup("#border_" + String.valueOf(valor));
destacadoBG = (Color) rectangle.getFill(); destacadoBG = (Color) rectangle.getFill();
} }
else if (tipo.equals("circulo")) { else if (this.tipo == CIRCULO) {
circle = (Circle) scene.lookup("#border_" + String.valueOf(valor)); circle = (Circle) scene.lookup("#border_" + String.valueOf(valor));
destacadoBG = (Color) circle.getFill(); destacadoBG = (Color) circle.getFill();
} }
@ -161,10 +174,10 @@ public class Grafico {
destacadoFG = (Color) text.getStroke(); destacadoFG = (Color) text.getStroke();
PauseTransition changeColor[] = new PauseTransition[Colores.MAX_COLORS]; PauseTransition changeColor[] = new PauseTransition[Colores.MAX_COLORS];
for (int i = 0; i < Colores.MAX_COLORS; i++) { for (int i = 0; i < Colores.MAX_COLORS; i++) {
if (tipo.equals("rectangulo")) { if (this.tipo == RECTANGULO) {
changeColor[i] = createPauseTransition(rectangle, text, colores.getFondo(), colores.getTexto()); changeColor[i] = createPauseTransition(rectangle, text, colores.getFondo(), colores.getTexto());
} }
else if (tipo.equals("circulo")) { else if (this.tipo == CIRCULO) {
changeColor[i] = createPauseTransition(circle, text, colores.getFondo(), colores.getTexto()); changeColor[i] = createPauseTransition(circle, text, colores.getFondo(), colores.getTexto());
} }
colores.siguinteColor(); colores.siguinteColor();
@ -180,11 +193,11 @@ public class Grafico {
public void removerDestacar() { public void removerDestacar() {
if (destacado != -1) { if (destacado != -1) {
blinkTransition.stop(); blinkTransition.stop();
if (tipo.equals("rectangulo")) { if (tipo == RECTANGULO) {
Rectangle rectangle = (Rectangle) scene.lookup("#border_" + String.valueOf(destacado)); Rectangle rectangle = (Rectangle) scene.lookup("#border_" + String.valueOf(destacado));
rectangle.setFill(destacadoBG); rectangle.setFill(destacadoBG);
} }
else if (tipo.equals("circulo")) { else if (tipo == CIRCULO) {
Circle circle = (Circle) scene.lookup("#border_" + String.valueOf(destacado)); Circle circle = (Circle) scene.lookup("#border_" + String.valueOf(destacado));
circle.setFill(destacadoBG); circle.setFill(destacadoBG);
} }

View File

@ -0,0 +1,49 @@
package cl.cromer.estructuras;
final public class ListaEnlazadaTipos {
/**
* Tipo simple.
*/
static final public int SIMPLE = 0;
/**
* Tipo circular.
*/
static final public int CIRCULAR = 1;
/**
* Tipo doblemente enlazada.
*/
static final public int DOBLEMENTE_ENLAZADA = 2;
/**
* El tipo elegido.
*/
private int tipo;
/**
* Inicilizar el tipo de lista enlazada.
* @param tipo int: El tipo de lista enlazada, {@value #SIMPLE}, {@value #CIRCULAR} o {@value #DOBLEMENTE_ENLAZADA}
*/
public ListaEnlazadaTipos(int tipo) {
switch (tipo) {
case SIMPLE:
this.tipo = SIMPLE;
break;
case CIRCULAR:
this.tipo = CIRCULAR;
break;
case DOBLEMENTE_ENLAZADA:
this.tipo = DOBLEMENTE_ENLAZADA;
break;
default:
this.tipo = SIMPLE;
}
}
/**
* Devolver el tipo de lista enlazada.
* @return int: El tipo.
*/
public int getTipo() {
return tipo;
}
}

View File

@ -0,0 +1,284 @@
package cl.cromer.estructuras;
import javafx.fxml.FXML;
import javafx.fxml.Initializable;
import javafx.scene.Scene;
import javafx.scene.control.ButtonBar;
import javafx.scene.control.ButtonType;
import javafx.scene.control.Dialog;
import javafx.scene.layout.VBox;
import javafx.scene.text.Text;
import java.net.URL;
import java.util.Random;
import java.util.ResourceBundle;
import java.util.Scanner;
import java.util.logging.Level;
/**
* Esta clase es para controlar todos la interfaz de ListaEnlazada.
* @author Chris Cromer
*/
public class ListaEnlazdaController implements Initializable {
/**
* La caja para ingresar textos.
*/
@FXML private TextFieldLimited valorLista;
/**
* Donde poner el contenido de array.
*/
@FXML private VBox contenidoLista;
/**
* Donde va el codigo a mostrar a la pantalla.
*/
@FXML private Text codigoLista;
/**
* La escena donde está cosas graficas.
*/
private Scene scene;
/**
* Donde está guardado los idiomas.
*/
private ResourceBundle resourceBundle;
/**
* El array usado en la aplicación.
*/
private Array array;
/**
* Grafico rectangulos.
*/
private Grafico grafico;
/**
* Inicializar todos los datos y dibujar las graficas.
* @param location URL: El URL de fxml en uso.
* @param resourceBundle ResourceBundle: Tiene datos de idioma.
*/
@Override
public void initialize(URL location, ResourceBundle resourceBundle) {
this.resourceBundle = resourceBundle;
scene = null;
Colores colores = new Colores();
for (int i = 0; i < 10; i++) {
contenidoLista.getChildren().addAll(Grafico.crearCaja(colores, String.valueOf(i)));
colores.siguinteColor();
}
}
/**
* Llenar el array con numeros al azar.
*/
@FXML
protected void botonLlenar() {
if (scene == null) {
initializeArray();
}
Random random = new Random();
int maximo = 99;
int minimo = 0;
int rango = maximo - minimo + 1;
for (int i = array.size(); i < 10; i++) {
int numero = random.nextInt(rango) + minimo;
while (array.buscar(numero) != -1) {
numero = random.nextInt(rango) + minimo;
}
array.insertar(numero);
}
generarGrafico();
}
/**
* Vaciar el array de todos los valores.
*/
@FXML
protected void botonVaciar() {
if (scene == null) {
initializeArray();
}
if (array.isOrdered()) {
array = new Array(10);
array.setOrdered(true);
}
else {
array = new Array(10);
array.setOrdered(false);
}
generarGrafico();
}
/**
* Insertar un valor al array y mostrar el codigo en la pantalla.
*/
@FXML
protected void botonInsertar() {
if (scene == null) {
initializeArray();
}
// Mostrar el codigo
String tipo = (array.isOrdered())?"Ordenado":"Simple";
String codigoTexto = new Scanner(getClass().getResourceAsStream("/cl/cromer/estructuras/code/array" + tipo + "/insertar")).useDelimiter("\\Z").next();
codigoLista.setText(codigoTexto);
if (valorLista.getText() != null && !valorLista.getText().trim().equals("")) {
try {
boolean exito = array.insertar(Integer.valueOf(valorLista.getText()));
if (exito) {
generarGrafico();
}
else {
ButtonType botonCerrar = new ButtonType(resourceBundle.getString("cerrar"), ButtonBar.ButtonData.OK_DONE);
Dialog<String> dialog = new Dialog<>();
dialog.setTitle(resourceBundle.getString("error"));
if (array.size() == 10) {
dialog.setContentText(resourceBundle.getString("arrayLleno"));
}
else {
dialog.setContentText(resourceBundle.getString("arrayValorExiste"));
}
dialog.getDialogPane().getButtonTypes().add(botonCerrar);
dialog.show();
}
}
catch (NumberFormatException exception) {
// El error no es fatal, sigue
Logs.log(Level.WARNING, "No es tipo int.");
errorNoValor();
}
}
else {
errorNoValor();
}
}
/**
* Eliminar un valor del array si existe y mostrar el codigo en la pantalla.
*/
@FXML
protected void botonEliminar() {
if (scene == null) {
initializeArray();
}
// Mostrar el codigo
String tipo = (array.isOrdered())?"Ordenado":"Simple";
String codigoTexto = new Scanner(getClass().getResourceAsStream("/cl/cromer/estructuras/code/array" + tipo + "/eliminar")).useDelimiter("\\Z").next();
codigoLista.setText(codigoTexto);
try {
if (valorLista.getText() != null && !valorLista.getText().trim().equals("")) {
boolean exito = array.eliminar(Integer.valueOf(valorLista.getText()));
if (exito) {
generarGrafico();
}
else {
errorNoEsta();
}
}
else {
errorNoValor();
}
}
catch (NumberFormatException exception) {
// El error no es fatal, sigue
Logs.log(Level.WARNING, "No es tipo int.");
errorNoValor();
}
}
/**
* Buscar si existe un elemento en el array y mostrar el codigo en la pantalla
* Si existe el valor destacarlo.
*/
@FXML
protected void botonBuscar() {
if (scene == null) {
initializeArray();
}
// Mostrar el codigo
String tipo = (array.isOrdered())?"Ordenado":"Simple";
String codigoTexto = new Scanner(getClass().getResourceAsStream("/cl/cromer/estructuras/code/array" + tipo + "/buscar")).useDelimiter("\\Z").next();
codigoLista.setText(codigoTexto);
try {
if (valorLista.getText() != null && !valorLista.getText().trim().equals("")) {
int encontrado = array.buscar(Integer.valueOf(valorLista.getText()));
if (encontrado != -1) {
generarGrafico();
grafico = new Grafico(scene);
grafico.destacer(encontrado, Grafico.RECTANGULO);
}
else {
errorNoEsta();
}
}
else {
errorNoValor();
}
}
catch (NumberFormatException exception) {
// El error no es fatal, sigue
Logs.log(Level.WARNING, "No es tipo int.");
errorNoValor();
}
}
/**
* Se muestra un error si la persona no ingresa un valor en el TextField.
*/
private void errorNoValor() {
ButtonType botonCerrar = new ButtonType(resourceBundle.getString("cerrar"), ButtonBar.ButtonData.OK_DONE);
Dialog<String> dialog = new Dialog<>();
dialog.setTitle(resourceBundle.getString("error"));
dialog.setContentText(resourceBundle.getString("arrayNoValor"));
dialog.getDialogPane().getButtonTypes().add(botonCerrar);
dialog.show();
}
/**
* Error cuando el valor no está en el array.
*/
private void errorNoEsta() {
ButtonType botonCerrar = new ButtonType(resourceBundle.getString("cerrar"), ButtonBar.ButtonData.OK_DONE);
Dialog<String> dialog = new Dialog<>();
dialog.setTitle(resourceBundle.getString("error"));
dialog.setContentText(resourceBundle.getString("arrayNoEsta"));
dialog.getDialogPane().getButtonTypes().add(botonCerrar);
dialog.show();
}
/**
* Crear el array de tamaño 10. La scene está usado para saber si es de tipo ordenado o simple segun el ménu.
*/
private void initializeArray() {
scene = contenidoLista.getScene();
grafico = new Grafico(scene);
this.array = new Array(10);
Array array = (Array) scene.getUserData();
this.array.setOrdered(array.isOrdered());
}
/**
* Poner los valores en el grafico.
*/
private void generarGrafico() {
grafico.removerDestacar();
for (int i = 0; i < 10; i++) {
Text text = (Text) scene.lookup("#caja_" + String.valueOf(i));
text.setText(array.getIndice(i));
}
}
}

View File

@ -15,6 +15,7 @@ import java.util.logging.Level;
* Estructuras de Datos * Estructuras de Datos
* Creado como proyecto semestral para la asignatura de estructuras de datos por la profesora Karina Rojas y el profesor Jorge Elgueta. * Creado como proyecto semestral para la asignatura de estructuras de datos por la profesora Karina Rojas y el profesor Jorge Elgueta.
* Creado en 2016-1 * Creado en 2016-1
* Se necesita java 8 instalado.
* @author Chris Cromer * @author Chris Cromer
* @version 1.0 * @version 1.0
*/ */
@ -58,7 +59,7 @@ public class Main extends Application {
stage.close(); stage.close();
} }
stage.setMaximized(true); //stage.setMaximized(true);
stage.setMinHeight(640); stage.setMinHeight(640);
stage.setMinWidth(768); stage.setMinWidth(768);
stage.show(); stage.show();

View File

@ -45,13 +45,12 @@ public class MenuController extends VBox implements Initializable {
*/ */
@FXML @FXML
protected void menuArraySimple() { protected void menuArraySimple() {
Array array = new Array(1); ArrayTipos arrayTipos = new ArrayTipos(ArrayTipos.SIMPLE);
array.setOrdered(false);
loadStage( loadStage(
resourceBundle.getString("tituloArraySimple"), resourceBundle.getString("tituloArraySimple"),
"/cl/cromer/estructuras/fxml/array.fxml", "/cl/cromer/estructuras/fxml/array.fxml",
"/cl/cromer/estructuras/css/style.css", "/cl/cromer/estructuras/css/style.css",
array arrayTipos
); );
} }
@ -60,13 +59,12 @@ public class MenuController extends VBox implements Initializable {
*/ */
@FXML @FXML
protected void menuArrayOrdenado() { protected void menuArrayOrdenado() {
Array array = new Array(1); ArrayTipos arrayTipos = new ArrayTipos(ArrayTipos.ORDENADO);
array.setOrdered(true);
loadStage( loadStage(
resourceBundle.getString("tituloArrayOrdenado"), resourceBundle.getString("tituloArrayOrdenado"),
"/cl/cromer/estructuras/fxml/array.fxml", "/cl/cromer/estructuras/fxml/array.fxml",
"/cl/cromer/estructuras/css/style.css", "/cl/cromer/estructuras/css/style.css",
array arrayTipos
); );
} }
@ -142,6 +140,20 @@ public class MenuController extends VBox implements Initializable {
); );
} }
/**
* Click en Lista Enlazada Simple.
*/
@FXML
protected void menuListaEnlazadaSimple() {
ListaEnlazadaTipos listaEnlazadaTipos = new ListaEnlazadaTipos(ListaEnlazadaTipos.SIMPLE);
loadStage(
resourceBundle.getString("tituloMerge"),
"/cl/cromer/estructuras/fxml/listaEnlazada.fxml",
"/cl/cromer/estructuras/css/style.css",
listaEnlazadaTipos
);
}
/** /**
* Click en Pila. * Click en Pila.
*/ */

View File

@ -90,7 +90,7 @@ public class Pila {
* @return String: El valor que está guardado en el indice. * @return String: El valor que está guardado en el indice.
*/ */
public String getIndice(int indice) { public String getIndice(int indice) {
if (indice >= 0 && indice < pila.length) { if (pila != null && indice >= 0 && indice < pila.length) {
return pila[indice]; return pila[indice];
} }
else { else {

View File

@ -192,7 +192,7 @@ public class PilaController implements Initializable {
int encontrado = pila.peek(); int encontrado = pila.peek();
if (encontrado != Integer.MIN_VALUE) { if (encontrado != Integer.MIN_VALUE) {
generarGrafico(); generarGrafico();
grafico.destacer(pila.size() - 1, "rectangulo"); grafico.destacer(pila.size() - 1, Grafico.RECTANGULO);
} }
else { else {
errorVacia(); errorVacia();

View File

@ -0,0 +1,30 @@
<?xml version="1.0" encoding="UTF-8"?>
<?import javafx.scene.control.*?>
<?import javafx.scene.layout.*?>
<?import cl.cromer.estructuras.TextFieldLimited?>
<?import javafx.scene.text.Text?>
<VBox xmlns:fx="http://javafx.com/fxml/1" prefHeight="768.0" prefWidth="1024.0" spacing="10" xmlns="http://javafx.com/javafx/8.0.92" fx:controller="cl.cromer.estructuras.ListaEnlazdaController">
<fx:include source="menu.fxml" />
<ScrollPane fitToHeight="true" fitToWidth="true" VBox.vgrow="ALWAYS">
<HBox alignment="TOP_CENTER" VBox.vgrow="ALWAYS" spacing="50">
<VBox spacing="10">
<HBox alignment="CENTER" spacing="10">
<Button text="%llenar" onAction="#botonLlenar" />
<Button text="%vaciar" onAction="#botonVaciar" />
</HBox>
<HBox alignment="CENTER" spacing="10">
<Button text="%insertar" onAction="#botonInsertar" />
<Button text="%eliminar" onAction="#botonEliminar" />
<Button text="%buscar" onAction="#botonBuscar" />
<TextFieldLimited fx:id="valorLista" maxLength="3" prefWidth="50" />
</HBox>
<VBox fx:id="contenidoLista" alignment="CENTER" />
</VBox>
<StackPane alignment="TOP_LEFT" minWidth="450">
<Text fx:id="codigoLista" />
</StackPane>
</HBox>
</ScrollPane>
</VBox>

View File

@ -17,7 +17,7 @@
<MenuItem text="%merge" onAction="#menuMerge"/> <MenuItem text="%merge" onAction="#menuMerge"/>
</Menu> </Menu>
<Menu text="%listaEnlazada"> <Menu text="%listaEnlazada">
<MenuItem text="%listaSimple"/> <MenuItem text="%listaSimple" onAction="#menuListaEnlazadaSimple"/>
<MenuItem text="%listaCircular"/> <MenuItem text="%listaCircular"/>
<MenuItem text="%doblementeEnlazada"/> <MenuItem text="%doblementeEnlazada"/>
</Menu> </Menu>