Mihai Sprinceana
Un forum de programare cu de toate. Va astept sa va inscrieti si sa deveniti moderatori. Oricine este binevenit aici sa se inscrie si sa aiba acces la informatie free! Fiecare este liber sa adauge proiecte programe free etc. Ajutati acest forum sa devina o comunitate puternica unde fiecare invata de la fiecare! Tot ce trebuie sa faceti este sa va inregistrati si fiecare contributie se poate dovedi utila in timp! Forumul este free informatia free dk aveti timp liber ajutati si pe ceilalti si invatati si voi in acelasi timp! Haideti sa facem ceva pt.a ne ajuta intre noi! Cititi regulament postare forum inainte de a posta!
Lista Forumurilor Pe Tematici
Mihai Sprinceana | Inregistrare | Login

POZE MIHAI SPRINCEANA

Nu sunteti logat.
Nou pe simpatie:
barbyy Profile
Femeie
23 ani
Bucuresti
cauta Barbat
23 - 80 ani
Mihai Sprinceana / C++ / Problema lsi- Stergerea a m inreg cu nr de ordine p1 Moderat de Alric2rei, Conan, cosmy, fireratbat, profu.info, sade5000
Autor
Mesaj Pagini: 1
mihaispr
Administrator

Inregistrat: acum 17 ani
Postari: 2142
//Creati o lista simplu inlantuita care permite stergerea a m inregistrari cu numar de ordine p1

#include<stdio.h>
#include<conio.h> //directiva pt.clrscr() si getch() din prog.principal void main()
#include<iostream.h> //directiva pt.afisarea nu cu printf ci cu cout<<"Mesaj:"<<variabila
#include<alloc.h> //directiva ce foloseste functiile de alocare new si dealocare delete
struct nod
{
int x;
struct nod* next;
}*l;

int n,i,q,t,p1,m;

struct nod* creare()
{
    struct nod* aux; int v;
    l=NULL;
    for(i=n;i>=1;i--)
    {
         aux= (struct nod* )malloc(sizeof(struct nod));
         printf("valoarea nodului %d=",i);
         scanf("%d",&v);
         aux->x=v;
         aux->next=l;
         l=aux;
     }
     return l;
}

void afisare()
{
struct nod* c;
printf("lista este" );
if (!l)
        printf("vida" );
else
    {
        c=l;
        while (c)
         {
             printf("%3d",c->x);
             c=c->next;
         }
    }
}

void stergere()
{struct nod* c;
c=l; //se pozitioneaza pe inregistrarea cu numar de ordine p1+1
for(i=1;i<=p1;i++)
{ t=c;// t este inregistrarea cu numar de ordine p1
   c=c->next;// c este inregistrarea cu numar de ordine p1+1
}
for(i=1;i<=m;i++)
q=c; //se pastreaza inregistrarea c intr-o variabila q
t->next=c->next; //se stabilesc legaturile intre vecinii lui q,t si c->next
delete q; //se distruge q
}

void main(void)
{
clrscr();
printf ("nr de noduri este:" );
scanf("%d",&n);
l=creare();
afisare();
stergere();
afisare();
getch();
}


pus acum 17 ani
   
Pagini: 1  

Mergi la