Advertisement
RiccardoMontagnin

Check sgrana

May 25th, 2015
289
0
Never
Not a member of Pastebin yet? Sign Up, it unlocks many cool features!
text 1.61 KB | None | 0 0
  1. dueL sgrana(nodo* L, int scatola){
  2.  
  3. cout<<"---Scatola n. "<<scatola<<"---"<<endl;
  4. if(L==0){ //Se sono arrivato a NULL (caso liste pari)...
  5.  
  6. cout<<"L->info = "<<L->info<<endl;
  7. cout<<"Arrivato alla fine"<<endl;
  8.  
  9. return dueL (L, L); //...entrambe le liste dovranno puntare a NULL
  10.  
  11. }
  12.  
  13.  
  14. if(L->next==0){ //Se sono all'ultima cifra e quello dopo è NULL (caso liste dispari)...
  15.  
  16. cout<<"L->info = "<<L->info<<endl;
  17. cout<<"Ultimo numero"<<endl;
  18.  
  19. return dueL (L, L->next); //la prima lista continuerà con il valore e poi NULL, e l'altra finirà con NULL
  20.  
  21. }
  22.  
  23.  
  24.  
  25. dueL V; //Variabile per il ritorno
  26.  
  27. V.prima = L; //Assegno primo valore
  28.  
  29. cout<<"V.prima assegnato"<<endl;
  30.  
  31. V.seconda = L->next; //Assegno secondo valore
  32.  
  33. cout<<"V.seconda assegnato"<<endl;
  34.  
  35. cout<<"L->info = "<<L->info<<endl;
  36. cout<<"L->next->next = "<<L->next->next<<endl;
  37.  
  38. V.prima -> next = sgrana(L->next->next, scatola+1).prima; //Continuo la prima lista
  39.  
  40. cout<<"---Scatola n. "<<scatola<<"---"<<endl;
  41. cout<<"V.prima -> next fatto"<<endl;
  42. cout<<"L->next->next = "<<L->next->next<<endl;
  43.  
  44. V.seconda -> next = sgrana (L->next->next, scatola +1).seconda; //Continuo la seconda lista
  45.  
  46. cout<<"---Scatola n. "<<scatola<<"---"<<endl;
  47. cout<<"V.seconda -> next fatto"<<endl;
  48. cout<<"L->next->next = "<<L->next->next<<endl;
  49.  
  50. return V;
  51.  
  52. }
Advertisement
Add Comment
Please, Sign In to add comment
Advertisement