fbpx

Problema #1168 – FAdaugareLaLista – Rezolvari PBInfo

de Mihai-Alexandru

Se consideră o listă liniară simplu înlănțuită, alocată dinamic, în care elementele sunt de tipul declarat mai jos:

struct nod{
    int info;
    nod * urm;
};

în care câmpul info memorează un număr întreg, iar câmpul urm memorează adresa următorului element al listei.

Cerinţa

Să se scrie o funcție C++ cu următorul prototip:

void adaugare(nod * & p , int x);

care adaugă valoarea x la sfârșitul listei pentru care primul element are adresa memorată în pointerul p.

Restricţii şi precizări

  • numele funcției va fi adaugare
  • dacă lista nu conține niciun element, pointerul p va avea valoarea NULL
  • în toate cazurile, la ieșirea din apel p va memora adresa primului element al listei

Important

Soluţia propusă va conţine definiţia funcţiei cerute. Prezenţa în soluţie a altor instrucţiuni poate duce erori de compilare sau de execuţie care vor avea ca efect depunctarea soluţiei.

void adaugare(nod* &prim , int x)
{
    nod* nou = new nod;///1
    nou -> info = x;///2
    nou -> urm = NULL;///3
    if(prim == NULL) prim = nou;///este primul
    else
    {
        nod* p = prim;///de la primul
        while(p -> urm != NULL)///pana la ultimul
            p = p -> urm;///parcurg
        p -> urm = nou;///4
    }
}
Comentarii

S-ar putea sa iti placa