edutedu

Liste1

Oct 7th, 2019
72
0
Never
Not a member of Pastebin yet? Sign Up, it unlocks many cool features!
text 1.35 KB | None | 0 0
  1. #include <iostream>
  2.  
  3.  
  4.  
  5. using namespace std;
  6.  
  7.  
  8.  
  9. struct elev{
  10.  
  11.     char nume[20];
  12.  
  13.     int h;
  14.  
  15.     elev *leg;
  16.  
  17. }*v[100];
  18.  
  19. int main()
  20.  
  21. {
  22.  
  23.     int n;
  24.  
  25.     cout<<"n="; cin>>n;
  26.  
  27.     for (int i=n-1; i>=0; i--){
  28.  
  29.         v[i]=new elev;
  30.  
  31.         cout<<"Elev: "<<i+1<<endl;
  32.  
  33.         cout<<"Nume: "; cin>>v[i]->nume;
  34.  
  35.         cout<<"H: "; cin>>v[i]->h;
  36.  
  37.         if (i==(n-1)) v[i]->leg=NULL;
  38.  
  39.         else v[i]->leg=v[i+1];
  40.  
  41.     }
  42.  
  43.     elev *p=new elev;
  44.  
  45.     p=v[0];
  46.  
  47.     while(p){
  48.  
  49.         cout<<p->nume<<", "<<p->h<<endl;
  50.  
  51.         p=p->leg;
  52.  
  53.     }
  54.  
  55.     //inserare 2/3
  56.  
  57.     cout<<"Introdu datele elevului nou:"<<endl;
  58.  
  59.     elev *elev_nou=new elev;
  60.  
  61.     cout<<"Nume: "; cin>>elev_nou->nume;
  62.  
  63.     cout<<"H: "; cin>>elev_nou->h;
  64.  
  65.     v[1]->leg=elev_nou;
  66.  
  67.     elev_nou->leg=v[2];
  68.  
  69.     p=v[0];
  70.  
  71.     cout<<"Lista dupa inserare:"<<endl;
  72.  
  73.     while(p){
  74.  
  75.         cout<<p->nume<<", "<<p->h<<endl;
  76.  
  77.         p=p->leg;
  78.  
  79.     }
  80.  
  81.     //stergere penultimul nod
  82.  
  83.     v[n-3]->leg=v[n-1];
  84.  
  85.     delete v[n-2];
  86.  
  87.     //dupa stergere:
  88.  
  89.     p=v[0];
  90.  
  91.     while(p){
  92.  
  93.         cout<<p->nume<<", "<<p->h<<endl;
  94.  
  95.         p=p->leg;
  96.  
  97.     }
  98.  
  99.     return 0;
  100.  
  101. }
Add Comment
Please, Sign In to add comment