Donada la classe Llista que permet guardar seqüències d’enters amb una llista doblement encadenada, circular i amb fantasma, cal implementar el mètode
que ordena eficientment els elements del paràmetre implícit de menor a major. No es poden usar estructures de dades auxiliars com els vectors o arrays.
Cal enviar a jutge.org la següent especificació de la classe Llista i la implementació del mètode dins del mateix fitxer. Al principi de cada mètode implementat, dins d’un comentari, cal indicar el cost temporal amb el raonament corresponent, incloent l’equació de la recurrència si fos necessari.
Per testejar la solució, jutge.org ja té implementats la resta de mètodes de la classe Llista i un programa principal que processa línies d’enters amb els que crea llistes i desprès crida el mètode ordena.
Entrada
L’entrada conté vàries línies formades per seqüències d’enters. Cadascuna d’elles són els elements que tindrà cada llista.
Sortida
Per a cada línia d’entrada, escriu una línia amb el resultat desprès d’haver ordenat els elements: El nombre d’elements de la llista seguit d’un espai, els elements de la llista entre claudàtors i separats per espais, i finalment aquests mateixos elements però amb ordre invers, també entre claudàtors i separats per espais.
Observació
Només cal enviar la classe requerida i la implementació del mètode ordena. Pots ampliar la classe amb mètodes privats. Segueix estrictament la definició de la classe de l’enunciat. No es poden usar estructures de dades auxiliars com els vectors o arrays.
Al principi de cada mètode implementat i dins d’un comentari cal indicar el cost temporal amb el raonament corresponent, incloent l’equació de la recurrència si fos necessari.
Input
Output
0 [] []
Input
5
Output
1 [5] [5]
Input
9 7 3 5
Output
2 [7 9] [9 7] 2 [3 5] [5 3]
Input
3 -6 8 0 4 -2 5 7 -3 3 9
Output
6 [-6 -2 0 3 4 8] [8 4 3 0 -2 -6] 5 [-3 3 5 7 9] [9 7 5 3 -3]
Input
1 2 3 4 5 6 7 8 9 9 8 7 6 5 4 3 2 1 0
Output
9 [1 2 3 4 5 6 7 8 9] [9 8 7 6 5 4 3 2 1] 10 [0 1 2 3 4 5 6 7 8 9] [9 8 7 6 5 4 3 2 1 0]