Hola, es normal que te surjan dudas, pero estoy seguro que con la ayuda que te demos y con un poco de paciencia no tendrás problema para comprender cómo resolver estos ejercicios.
Te explico con un poco más de detalle el procedimiento para el ejemplo "Caso 1".
Caso 1 33 - 88 - 57 - 22 - 15
Vamos a trabajar con dos listas, una lista con los valores iniciales que tenemos, que son v(1) = 33, v(2) = 88, v(3) = 57, v(4) = 22 y v(5) = 15. Estos son los valores originales.
En otra lista vamos a tener los números ordenados, podríamos decir que o(1) será el valor más grande, o(2) el siguiente valor, ... hasta o(5) que será el valor más pequeño, ya que vamos a ordenar de mayor a menor.
Inicialmente la lista de órdenes suponemos que está vacía, o para facilitar las comparaciones, diremos que o(1) = - 9999999 , o(2) = - 9999999, ... o(5) = - 9999999 Esto lo que significa es que la lista de números ordenados no tiene valores asignados, pero como vamos a hacer comparaciones con operadores matemáticos suponemos que los elementos contienen valores muy pequeños de forma que en cualquier comparación que hagamos o(x) va a ser más pequeño que v(x)
Paso 1)
Empezamos comparando el valor 1 de la lista original (33) con el orden 1 de la lista de números ordenados (-9999999). v(1) resulta mayor que o(1) porque cualquier número será mayor que o(1). Como v(1) es el mayor número que hemos visto por el momento, decimos que o(1) toma el valor de v(1), es decir o(1) ahora vale 33. Ahora el mayor número que hemos visto está en o(1) y marcamos como previsto para eliminar de la lista original v(1). Si se confirma que v(1) es el mayor valor lo eliminaremos al final, pero si aparece otro número mayor no eliminaremos v(1), sino aquel que resulte mayor. El número que eliminaremos de la lista original será el mayor entre los que queden.
v(1) > o(1) ? -> Sí -> o(1) = v(1) ; Previsto eliminar: v(1)
Ahora comparamos el valor 2 de la lista original con el mayor número que hemos visto hasta ahora, que está almacenado en o(1) y es 33
v(2) > o(1) ? -> Sí -> o(1) = v(2) ; Previsto eliminar: v(2)
v(2) es 88 y resulta mayor que 33, por eso ahora ponemos el mayor número que hemos visto, que es 88, en o(1) y decimos que el número que tenemos previsto eliminar de la lista original es v(2) porque es el mayor entre los números existentes en la lista de v´s.
v(3) > o(1) ? -> No ya que 57 no es mayor que 88
v(4) > o(1) ? -> No ya que 22 noes mayor que 88
v(5) > o(1) ? -> No ya que 15 no es mayor que 88
o(1) = v(2) Eliminado v(2)
De forma definitiva o(1) = 88, es decir, el mayor número es 88 y lo guardamos en o(1). A su vez, eliminamos v(2) de la lista de v´s porque ya lo hemos ordenado y no queremos volver a repetir comparaciones con él.
En el paso 2 operamos de la misma manera. La única diferencia es que los valores de v que ya estén eliminados (lo cual significa que ya están ordenados) no los tendremos en cuenta, simplemente indicaremos que ya están ordenados.
En el paso 2 tenemos para ordenar v(1), v(3), v(4) y v(5) ya que v(2) ya ha sido eliminado.
Ahora vamos a buscar el número más grande entre los valores de la lista v actual y asignárselo a o(2). El valor más grande resulta ser 57 que es v(3), por lo que hacemos o(2) = 57 y eliminamos v(3).
El proceso continua hasta que todos los valores v quedan eliminados, y la lista ordenada la tenemos en o(1), o(2), ... o(5).
Intenta hacerlo tú mismo, si tienes problemas en algún paso indica en cuál. Saludos.