Modifiqueu la classe List per a fer que els iteradors es comportin de
manera circular, és a dir, que si un iterador
it està situat al
end de la llista i fem
++it o it++, llavors
es posicionarà al begin de la llista, i si un
iterador it és al
begin de la llista i fem
–it o it–, llavors
es posicionarà al end de la llista.
D’entre els fitxers que s’adjunten en aquest exercici, trobareu
list.hh, a on hi ha una implementació de la
classe genèrica List. Haureu de buscar dins
list.hh els mètodes d’increment i decrement
d’iteradors i modificar-los convenientment. No toqueu la resta de la
implementació de la classe, excepte si, per algun motiu, considereu que
necessiteu afegir algun mètode auxiliar a la part privada. Només cal que
modifiqueu els iteradors mutables; els iteradors constants no es
consideren en aquest exercici.
D’entre els fitxers que s’adjunten a l’exercici també hi ha
main.cc (programa principal), i el podeu
compilar directament, doncs inclou list.hh.
Només cal que pugeu list.hh al jutge.
La entrada del programa és una seqüència d’instruccions del següent tipus que s’aniran aplicant sobre una llista que se suposa inicialment buida i un iterador que se suposa situat inicialment al principi (i final) d’aquesta llista:
push_front x (x és un string)
push_back x (x és un string)
pop_front
pop_back
it++
++it
it--
--it
*it
Se suposa que la seqüència d’entrada serà correcta (sense
pop_front ni
pop_back sobre llista buida, ni
it tenint it situat
al end de la llista). Tampoc hi haurà
pop_front just quan l’iterador estigui
apuntant al primer element de la llista, ni hi haurà
pop_back just quan l’iterador estigui apuntant
a l’últim element de la llista (tingueu en compte que l’últim element de
la llista no és el end de la llista).
El programa principal que us oferim ja s’encarrega de llegir aquestes entrades i fer les crides als corresponents mètodes de la classe list. Només cal que implementeu el mètode abans esmentat.
Per a cada instrucció it, s’escriurà el
contingut apuntat per l’iterador. El programa que us oferim ja fa això.
Només cal que implementeu el mètode abans esmentat.
Input
it-- --it it++ ++it push_front a it++ *it ++it ++it *it it++ it++ *it --it --it *it it-- it-- *it ++it pop_back push_back b --it *it push_back c *it --it it-- *it --it pop_back *it push_back d *it --it push_back e it-- *it push_back f ++it *it push_front g it++ it++ *it ++it *it it++ *it
Output
a a a a a b b c b b e f g b d
Input
it-- push_front d pop_front ++it it++ it++ --it push_back a --it *it ++it pop_front it++ push_front b pop_front push_back d pop_back push_front b pop_back --it push_front a push_back c it++ *it pop_back it++ push_front b ++it *it pop_back ++it pop_back push_back c pop_back ++it it++ it++ push_back c push_back d pop_front it++ *it
Output
a a b d