Implementeu un nou mètode de la classe Stack que rebi un element com a paràmetre i esborri la primera ocurrència (primera des del cim) d’aquest element, si existeix.
D’entre els fitxers que s’adjunten en aquest exercici, trobareu
stack.old.hpp, a on hi ha una implementació de
la classe genèrica Stack. En primer lloc,
haureu de fer:
cp stack.old.hpp stack.hpp
A continuació, haureu de buscar dins
stack.hpp la part:
// Pre:
// Post: La primera ocurrència de 'value' en la pila implícita ha estat esborrada.
// Si no hi havia cap ocurrència de 'value', llavors no ha canviat res.
// Descomenteu les següents dues linies i implementeu la funció:
// void removeFirstOccurrence(T value) {
// }
Haureu de descomentar les dues línies que s’indiquen i implementar aquest mètode. 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.
Preferiblement, haurieu d’aconseguir implementar
removeFirstOccurrence a base d’avançar pels
punters de l’objecte. De fet, una implementació a base d’usar
push i pop us
permetrà passar els jocs de proves públics (i així obtenir una part de
la nota), però no els privats. Recordeu que és important alliberar la
memòria que ja no s’utilitzarà més.
D’entre els fitxers que s’adjunten a l’exercici també hi ha
program.cpp (programa principal) i
Makefile per a compilar. Per a pujar la vostra
solució, heu de crear el fitxer solution.tar
així:
tar cf solution.tar stack.hpp
La entrada del programa és una seqüència d’instruccions del següent tipus que s’aniran aplicant sobre una pila que se suposa inicialment buida:
push x (x és un string)
pop
top
size
removeFirstOccurrence x (x és un string)
Se suposa que la seqüència d’entrada serà correcta (sense pop ni top sobre pila buida).
El programa principal que us oferim ja s’encarrega de llegir aquestes entrades i fer les crides als corresponents mètodes de la classe pila. Només cal que implementeu el mètode abans esmentat.
Per a cada instrucció top, s’escriurà el
top actual de la pila. Per a cada instrucció
size, s’escriurà la mida de la pila. El
programa que us oferim ja fa això. Només cal que implementeu el mètode
abans esmentat.
Avaluació sobre 10 punts:
Solució lenta: 6 punts.
solució ràpida: 10 punts.
Input
removeFirstOccurrence e removeFirstOccurrence a push a top removeFirstOccurrence a push b size top removeFirstOccurrence c top push d push f size removeFirstOccurrence d top push f top removeFirstOccurrence f size top removeFirstOccurrence a top removeFirstOccurrence b top
Output
a 1 b b 3 f f 2 f f f
Input
push ab pop removeFirstOccurrence ba push c push ad size removeFirstOccurrence c size size size push c pop push ca pop push a pop push c removeFirstOccurrence c top top push bc size top removeFirstOccurrence bc size size push ab size removeFirstOccurrence ad push ad size top push bc pop pop size push da pop pop push a push ba removeFirstOccurrence b removeFirstOccurrence a pop size push bc top push c top push dc push d top top removeFirstOccurrence dc top push b size pop pop removeFirstOccurrence c top
Output
2 1 1 1 ad ad 2 bc 1 1 2 2 ad 1 0 bc c d d d 4 bc