Ejemplo 1:
La selección ordena itera sobre los elementos en la matriz no organizada especificada. El elemento mínimo se selecciona y se mueve a la subarrray clasificada en cada iteración del tipo de selección. El siguiente programa se utiliza para el tipo de selección para ordenar una matriz en orden ascendente:
La clase "AscendingSelectionSort" está construida en el programa Java que se menciona anteriormente. Esta clase se implementa con la función Void "Sort" donde se pasa la matriz de enteros "MyArray" un parámetro. Dentro de la función de "ordenar", decalamos el objeto "Arraysize" para obtener el tamaño de la matriz desde el método de longitud. Además, implementamos el método for-bucle que itera el límite de la matriz no organizada, uno a la vez.
El siguiente paso es desarrollar un objeto llamado "min" que localice el elemento de matriz no organizado con el valor más bajo. Se invoca el otro bucle for-loop para obtener la posición de índice del elemento mínimo de la matriz. El bucle de la forma de "i+1" al último elemento de una matriz. A continuación, tenemos una declaración IF para verificar si el "MyArray [J]" es más pequeño que "MyArray [min]" o no. Si es así, el índice mínimo se incrementará. Luego, aplicamos el algoritmo de intercambio cambiando el valor mínimo de la matriz con el primer valor. Allí, tenemos otra función, el "printArray", que se establece para imprimir la matriz ordenada desde el tipo de selección. Imprimimos la matriz ordenada iterando cada elemento de la matriz a través del bucle for-loop.
Al final, probamos la implementación del tipo de selección dentro del método Main (). Aquí, definimos el objeto "OBJ" para la clase "AscendingSelectionSort" y también inicializamos la matriz "MyArray" con los elementos enteros. Luego, usamos la función de "ordenar" usando esa matriz como parámetro para ordenar la matriz, que luego se imprimió en la consola.
La técnica de clasificación de selección se utiliza para producir la siguiente matriz que se clasifica en orden ascendente:
Ejemplo 2:
El tipo de selección también se puede usar para la matriz que no está preestablecida. El usuario primero ingresa al tamaño de la matriz. Luego, ingresa al elemento dentro de la matriz con la matriz especificada.
En el programa anterior de Java, definimos la clase "UserDefinedSelectionsort". La clase se define con la función de "intercambio" y toma la "X []", "I" y "J" como parámetros. Los elementos de la matriz se comparan primero y luego se intercambian con la variable "temperatura". Después de eso, tenemos otra función: "UserDefinedSelectionsort", donde la matriz "X []" y el tamaño del objeto se define como un parámetro. Esta función se llama con el bucle forestal anidado. Primero atravesamos la matriz sin clasificar desde el primer índice hasta el último.
Luego, atravesamos la matriz no ordenada de "i+1" al último valor de la matriz para obtener el elemento mínimo de la matriz no organizada y actualizar el índice mínimo. Después de eso, llamamos a la función de "intercambio" para intercambiar la x [i] con la x [min_index]. Luego, tenemos un formulario de método main () donde tomamos la entrada del usuario creando el objeto "entrada" y llamando al sistema en el método. El objeto "S" denota la longitud de la matriz que usa el método NextInt () para leer el siguiente token del valor de entrada por parte del usuario. La longitud de la matriz se declara dentro de la matriz "x []" y luego se obtiene como el valor para la matriz dentro del tamaño de la matriz. La matriz inicial se muestra primero, luego la matriz ordenada desde el método de clasificación de selección se atraviesa y se muestra.
En la compilación del código anterior, el terminal primero pidió ingresar al tamaño de la matriz. Después de definir el tamaño de la matriz, el usuario ingresa los elementos aleatorios. Entonces, el tipo de selección se realiza. La matriz inicial no organizada y la matriz ordenada de selección se muestran en lo siguiente:
Ejemplo 3:
A continuación, el tipo de selección se realiza en la lista vinculada individualmente. La técnica implica el intercambio del nodo de lista vinculado en lugar de los datos dentro de los nodos.
En el programa anterior, tenemos una clase Java "LinkedListSelectionsorts" donde definimos otra clase, el "nodo". La clase "nodo" se declara con el objeto "myData" y el objeto nodo, "next_node". Luego, tenemos una función de "swapnodes" donde el nodo actual "Curr_n1" se intercambia con otro nodo actual "Curr_n2" sin intercambiar los elementos de nodo en la lista vinculada. Primero, hicimos el "curr_n2" por delante y luego ajustamos los enlaces. Después de eso, intercambiamos los nodos con la variable temperada.
Allí, tenemos otra función de "SelectionSort" que utiliza el enfoque de clasificación de selección recursiva para ordenar la lista vinculada. Descubrimos con el estado if si la lista vinculada tiene el nodo. Luego, definimos el nodo del puntero "min_node" para el valor de datos mínimo y el puntero del nodo "prev_min" para tener el valor de datos anterior del nodo. El circuito for-loop atraviesa todos los nodos de la lista vinculada e incrementa el nodo mínimo y el nodo anterior. A continuación, aplicamos la condición: si el nodo min_node y el nodo de la cabeza son diferentes, cambiamos el min_node con el nodo de la cabeza. La lista vinculada restante se ordena recursivamente colocando la "cabeza.next_node "en la función SelectionSort.
Además, creamos la función "Sortnodes" que verifica que la lista vinculada dada no debe estar vacía y ordene la lista a través de la función SelectionSort (). Luego, tenemos la siguiente función que es "presionar" para agregar un nodo a la posición inicial de la lista vinculada. Definimos el objeto "Newnode" para asignar el nodo e insertar los datos dentro de ese nodo. Después de eso, vinculamos la referencia del cabezal con el nuevo nodo y reasignamos la referencia de la cabeza a un nuevo nodo. A continuación, creamos una función de "lista de visualización" para imprimir la lista vinculada a través del bucle while.
Tenemos un método main () donde la lista vinculada se inicializa utilizando el método de push. Se imprimirán los elementos de la lista vinculados sin clasificar. Luego, invocamos la función sortNodes () que toma el objeto Head como un parámetro para realizar la operación de clasificación de selección. La lista vinculada ordenada se imprime mediante el método DisplayList () que también toma la "Cabeza" como argumento.
Se muestra la lista vinculada original. Después de eso, la lista vinculada ordenada se imprime en lo siguiente:
Conclusión
El orden de selección esencialmente especifica dónde comienza un elemento desde los otros elementos. El tipo de selección en Java se aplica cuando las listas pequeñas deben ordenarse. También afecta la tasa de escritura a la memoria, especialmente la memoria flash. El concepto central de usar el tipo de selección en Java es dividir una matriz en las secciones ordenadas y no organizadas y luego ordenar la matriz usando comparaciones. Los ejemplos de clasificación de selección se demuestran con el valor predeterminado y el otro caso.