PILA X93995


Statement
 

pdf   zip   tar

html

Implementeu un nou mètode de la classe Stack que esborri de la pila donada l’element introduït a la entrada del programa en cas que aquest estigui en una posició parell considerant el top amb index 0. Si aquest element es troba diverses vegadas a la pila, nomes tenim en compte la primera vegada que apareix en una posicio parell. En el cas especial en que hi hagi només un element, llavors esborrarà aquest element. S’assumeix que el cas especial en que no hi hagi cap element no pasarà res. 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 aquesta està en una posició parell.
 //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 de treballar amb els punters de l’objecte. 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

Només cal que implementeu el mètode abans esmentat. Tindrà com a sortida per a cada pila, la pila resultant d’haver esborrat el string donat. En cas que aquest valor no es trobi a la pila, sortiria per pantalla la inicial.

Entrada

La entrada del programa és una seqüència de strings del següent tipus que s’aniran aplicant sobre una pila que se suposa inicialment buida:

cd
lrbbm b cd rzo k yhidd

Se suposa que la seqüència d’entrada serà correcta (sense pop ni top ni top2 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.

Sortida

Només cal que implementeu el mètode abans esmentat. Tindrà com a sortida per a cada pila, la pila resultant d’haver esborrat el string donat. En cas que aquest valor no es trobi a la pila, sortiria per pantalla la inicial.

lrbbm b cd rzo k yhidd
Public test cases
  • Input

    cd
    lrbbm b cd rzo k yhidd
    mowfrx
    xr mowfrx jybld efsarc ynecdy
    pkm
    pklo ellnmp p fwk
    fwzqfj
    qhn nku whs mgbbu clj ivswmd qtb ixmvtr bljp ns fwzqfj
    vqh
    drr s fsbcn vqh
    fgdwdwf
    aqxwp caceh hzv rk lnozj p pxr xkit yxac hh icq oendt
    ordtqk
    p iqvkuy dl gdewh acio ordtqk wcsgsp
    nsadeu
    sbo guw nyqxnz gdgw btrw
    d
    u oqc ru et kyx oach d
    yxlm
    rd yxlm dqtukw g
    

    Output

    lrbbm b cd rzo k yhidd
    
    xr mowfrx jybld efsarc ynecdy
    
    pklo ellnmp p fwk
    
    qhn nku whs mgbbu clj ivswmd qtb ixmvtr bljp ns
    
    drr s fsbcn
    
    aqxwp caceh hzv rk lnozj p pxr xkit yxac hh icq oendt
    
    p iqvkuy dl gdewh acio ordtqk wcsgsp
    
    sbo guw nyqxnz gdgw btrw
    
    u oqc ru et kyx oach
    
    rd dqtukw g
    
  • Input

    bmq
    lr bmq h
    zo
    zo k yh ddq cdx jm w rxs yb d efs rcb ne dyg xx k
    q
    ll mpa q w hop m oqh wnk e h qm b u clj ivs md qtb ixm t
    acehchzvfr
    j t s fwz fj afa rrw o sbc uvq f bsa xwp
    co
    ln zj p pxr x itz x cbh kic co n t m g wdw cgp iqv uyt
    dew
    dew tac oh rd qk wcs
    eu
    oqm boa u nny xnz g gw b rwb n a eu uum q d u et kyx o
    lejuuk
    d mx rd y lm dqt kwa
    bum
    ibx bum
    yat
    yat r yd ajx

    Output

    lr bmq h
    
    zo k yh ddq cdx jm w rxs yb d efs rcb ne dyg xx k
    
    ll mpa w hop m oqh wnk e h qm b u clj ivs md qtb ixm t
    
    j t s fwz fj afa rrw o sbc uvq f bsa xwp
    
    ln zj p pxr x itz x cbh kic n t m g wdw cgp iqv uyt
    
    dew tac oh rd qk wcs
    
    oqm boa u nny xnz g gw b rwb n a eu uum q d u et kyx o
    
    d mx rd y lm dqt kwa
    
    ibx
    
    yat r yd ajx
    
  • Information
    Author
    Alumnepro12223_
    Language
    Catalan
    Official solutions
    Make
    User solutions
    Make