Torna indietro   Hardware Upgrade Forum > Software > Programmazione

Roborock Qrevo Curv 2 Flow: ora lava con un rullo
Roborock Qrevo Curv 2 Flow: ora lava con un rullo
Qrevo Curv 2 Flow è l'ultima novità di casa Roborock per la pulizia di casa: un robot completo, forte di un sistema di lavaggio dei pavimenti basato su rullo che si estende a seguire il profilo delle pareti abbinato ad un potente motore di aspirazione con doppia spazzola laterale
Alpine A290 alla prova: un'auto bella che ti fa innamorare, con qualche limite
Alpine A290 alla prova: un'auto bella che ti fa innamorare, con qualche limite
Abbiamo guidato per diversi giorni la Alpine A290, la prima elettrica del nuovo corso della marca. Non è solo una Renault 5 sotto steroidi, ha una sua identità e vuole farsi guidare
Recensione HONOR Magic 8 Lite: lo smartphone indistruttibile e instancabile
Recensione HONOR Magic 8 Lite: lo smartphone indistruttibile e instancabile
Abbiamo provato a fondo il nuovo Magic 8 Lite di HONOR, e per farlo siamo volati fino a Marrakech , dove abbiamo testato la resistenza di questo smartphone in ogni condizione possibile ed immaginabile. Il risultato? Uno smartphone praticamente indistruttibile e con un'autonomia davvero ottima. Ma c'è molto altro da sapere su Magic 8 Lite, ve lo raccontiamo in questa recensione completa.
Tutti gli articoli Tutte le news

Vai al Forum
Rispondi
 
Strumenti
Old 17-05-2013, 18:23   #1
Heretic Curse
Member
 
Iscritto dal: Mar 2011
Messaggi: 125
[Python] Risolto un problema se ne crea un altro

Ok, vi dico subito: rilassatevi . Questa volta non ho un codice che non funziona per via della mia sbadataggine, semplicemente sono andato avanti di circa mezzo capitolo di "Pensare in Python", e ho trovato un codice che, per quanto funzioni, non riesco a comprendere.
Codice:
class Nodo:
  def __init__(self, Contenuto=None, ProssimoNodo=None):
    self.Contenuto = Contenuto
    self.ProssimoNodo = ProssimoNodo

  def __str__(self):
    return str(self.Contenuto)

def StampaInversa(Lista):
    if Lista == None: return
    Testa = Lista
    Coda = Lista.ProssimoNodo
    StampaInversa(Coda)
    print Testa,

Nodo1 = Nodo(1)
Nodo2 = Nodo(2)
Nodo3 = Nodo(3)
Nodo1.ProssimoNodo = Nodo2
Nodo2.ProssimoNodo = Nodo3
StampaInversa(Nodo1)
E viene restituito:
Codice:
3 2 1
che è proprio quello che voglio. Tuttavia non ho ben capito perché questo codice funziona:
-Testa = Nodo1
-Coda = Nodo2
-Testa = Nodo2
-Coda = Nodo3
-la condizione risulta positiva e quindi si attiva return, e penso che ciò che non capisco riguardi questa funzione
-(supponendo che in qualche strano modo vengano saltate le tre righe successive) viene stampato Testa, ovvero Nodo3. Com'è che vengono restituiti pure gli attributi degli altri Nodi?
Heretic Curse è offline   Rispondi citando il messaggio o parte di esso
Old 17-05-2013, 20:29   #2
kwb
Senior Member
 
L'Avatar di kwb
 
Iscritto dal: Jul 2003
Città: Alessandria
Messaggi: 10167
Quote:
Originariamente inviato da Heretic Curse Guarda i messaggi
Ok, vi dico subito: rilassatevi . Questa volta non ho un codice che non funziona per via della mia sbadataggine, semplicemente sono andato avanti di circa mezzo capitolo di "Pensare in Python", e ho trovato un codice che, per quanto funzioni, non riesco a comprendere.
Codice:
class Nodo:
  def __init__(self, Contenuto=None, ProssimoNodo=None):
    self.Contenuto = Contenuto
    self.ProssimoNodo = ProssimoNodo

  def __str__(self):
    return str(self.Contenuto)

def StampaInversa(Lista):
    if Lista == None: return
    Testa = Lista
    Coda = Lista.ProssimoNodo
    StampaInversa(Coda)
    print Testa,

Nodo1 = Nodo(1)
Nodo2 = Nodo(2)
Nodo3 = Nodo(3)
Nodo1.ProssimoNodo = Nodo2
Nodo2.ProssimoNodo = Nodo3
StampaInversa(Nodo1)
E viene restituito:
Codice:
3 2 1
che è proprio quello che voglio. Tuttavia non ho ben capito perché questo codice funziona:
-Testa = Nodo1
-Coda = Nodo2
-Testa = Nodo2
-Coda = Nodo3
-la condizione risulta positiva e quindi si attiva return, e penso che ciò che non capisco riguardi questa funzione
-(supponendo che in qualche strano modo vengano saltate le tre righe successive) viene stampato Testa, ovvero Nodo3. Com'è che vengono restituiti pure gli attributi degli altri Nodi?
Il metodo StampaInversa è un metodo ricorsivo, ovvero che richiama se stesso.
Prima che venga fatta la prima chiamata a StampaInversa hai Nodo1, Nodo2 completamente definiti ( ovvero hanno sia un attributo Contenuto che un attributo ProssimoNodo definito ). Nodo3 invece ha solo l'attributo Contenuto definito, mentre ProssimoNodo è uguale a None ( come indicato tra i parametri del costruttore ).

Detto ciò, quando chiami per la prima volta StampaInversa questo è quello che succede:
1. Nodo1 è uguale a None? FALSO
2. Imposti Testa = Nodo1
3. Imposti Coda = Nodo2
4. Chiama StampaInversa(Nodo2) [Nota che qua si chiama Coda, ma Coda= Nodo2]

5. Nodo2 è uguale a None? FALSO
6. Imposti Testa = Nodo2
7. Imposti Coda = Nodo3
8. Chiama StampaInversa(Nodo3) [Nota che qua si chiama Coda, ma Coda= Nodo3]

9. Nodo3 è uguale a None? FALSO
10. Imposti Testa = Nodo3
11. Imposti Coda = None
12. Chiama StampaInversa(None) [Nota che qua si chiama Coda, ma Coda= None]

13. None è uguale a None? VERO -> Esci dalla funzione

14. Ora siamo dentro StampaInversa di Nodo3. Subito la chiama alla funzione StampaInversa(None) c'è print Testa, quindi:
15. Stampa Nodo3
16. Esci da StampaInversa
17. Stampa Nodo2
18. Esci da StampaInversa
19. Stampa Nodo1
20. Esci da StampaInversa

21. Esci dal programma
__________________
Dell XPS 13 (9350) :: i5-2500K - HD6870 - AsRock Z68 Pro3 - Corsair Vengeance 8GB (4x2) DDR3 :: Samsung Galaxy S4 GT-i9505
kwb è offline   Rispondi citando il messaggio o parte di esso
Old 17-05-2013, 21:05   #3
Heretic Curse
Member
 
Iscritto dal: Mar 2011
Messaggi: 125
Quote:
Originariamente inviato da kwb Guarda i messaggi
Il metodo StampaInversa è un metodo ricorsivo, ovvero che richiama se stesso.
Prima che venga fatta la prima chiamata a StampaInversa hai Nodo1, Nodo2 completamente definiti ( ovvero hanno sia un attributo Contenuto che un attributo ProssimoNodo definito ). Nodo3 invece ha solo l'attributo Contenuto definito, mentre ProssimoNodo è uguale a None ( come indicato tra i parametri del costruttore ).

Detto ciò, quando chiami per la prima volta StampaInversa questo è quello che succede:
1. Nodo1 è uguale a None? FALSO
2. Imposti Testa = Nodo1
3. Imposti Coda = Nodo2
4. Chiama StampaInversa(Nodo2) [Nota che qua si chiama Coda, ma Coda= Nodo2]

5. Nodo2 è uguale a None? FALSO
6. Imposti Testa = Nodo2
7. Imposti Coda = Nodo3
8. Chiama StampaInversa(Nodo3) [Nota che qua si chiama Coda, ma Coda= Nodo3]

9. Nodo3 è uguale a None? FALSO
10. Imposti Testa = Nodo3
11. Imposti Coda = None
12. Chiama StampaInversa(None) [Nota che qua si chiama Coda, ma Coda= None]

13. None è uguale a None? VERO -> Esci dalla funzione

14. Ora siamo dentro StampaInversa di Nodo3. Subito la chiama alla funzione StampaInversa(None) c'è print Testa, quindi:
15. Stampa Nodo3
16. Esci da StampaInversa
17. Stampa Nodo2
18. Esci da StampaInversa
19. Stampa Nodo1
20. Esci da StampaInversa

21. Esci dal programma
Fino al 13 avevo capito (anche se l'ho spiegato un po' con i piedi). Adesso vediamo se ho compreso bene il resto: in pratica quando la condizione diventa vera esce dalla funzione, che però era quella interna che agiva su None, e così rientra nella StampaInversa di Nodo3, la completa col print, rientra in quella di Nodo2, completa col print, e poi idem con Nodo1.
Riformulando: le StampaInversa restano in stasi finché Lista non è uguale a None, così interrompe quella attuale (che agiva appunto su None) e poi ritorna sulle altre partendo dalla più recente, così da compierle a ritroso.

Grazie mille
Heretic Curse è offline   Rispondi citando il messaggio o parte di esso
Old 17-05-2013, 21:21   #4
kwb
Senior Member
 
L'Avatar di kwb
 
Iscritto dal: Jul 2003
Città: Alessandria
Messaggi: 10167
Quote:
Originariamente inviato da Heretic Curse Guarda i messaggi
Fino al 13 avevo capito (anche se l'ho spiegato un po' con i piedi). Adesso vediamo se ho compreso bene il resto: in pratica quando la condizione diventa vera esce dalla funzione, che però era quella interna che agiva su None, e così rientra nella StampaInversa di Nodo3, la completa col print, rientra in quella di Nodo2, completa col print, e poi idem con Nodo1.
Riformulando: le StampaInversa restano in stasi finché Lista non è uguale a None, così interrompe quella attuale (che agiva appunto su None) e poi ritorna sulle altre partendo dalla più recente, così da compierle a ritroso.

Grazie mille
Si in buona sostanza è così.
__________________
Dell XPS 13 (9350) :: i5-2500K - HD6870 - AsRock Z68 Pro3 - Corsair Vengeance 8GB (4x2) DDR3 :: Samsung Galaxy S4 GT-i9505
kwb è offline   Rispondi citando il messaggio o parte di esso
 Rispondi


Roborock Qrevo Curv 2 Flow: ora lava con un rullo Roborock Qrevo Curv 2 Flow: ora lava con un rull...
Alpine A290 alla prova: un'auto bella che ti fa innamorare, con qualche limite Alpine A290 alla prova: un'auto bella che ti fa ...
Recensione HONOR Magic 8 Lite: lo smartphone indistruttibile e instancabile Recensione HONOR Magic 8 Lite: lo smartphone ind...
Sony WF-1000X M6: le cuffie in-ear di riferimento migliorano ancora Sony WF-1000X M6: le cuffie in-ear di riferiment...
Snowflake porta l'IA dove sono i dati, anche grazie a un accordo con OpenAI Snowflake porta l'IA dove sono i dati, anche gra...
Il sistema di verifica dell'identit&agra...
Ora è ufficiale: Samsung sta per ...
Motorola Edge 70 Fusion: ecco le specifi...
8TB a meno di 170€: il richiestissimo Ha...
Il nuovo MacBook 'low cost' arriver&agra...
Pokémon Rosso Fuoco e Verde Fogli...
Risparmiare con le offerte Amazon: weeke...
Gli Xiaomi 17 arrivano a fine febbraio, ...
48.000 Pa a poco più di 100€: la ...
PC più potente, meno spesa: su Amazon to...
Con 2 acquisti si ottiene il 40% di scon...
Blocco VPN in Spagna durante le partite ...
ECOVACS DEEBOT T30C OMNI GEN2 torna a 34...
Cercate uno smartphone? Ecco 7 modelli i...
Paramount non molla: Netflix è pr...
Chromium
GPU-Z
OCCT
LibreOffice Portable
Opera One Portable
Opera One 106
CCleaner Portable
CCleaner Standard
Cpu-Z
Driver NVIDIA GeForce 546.65 WHQL
SmartFTP
Trillian
Google Chrome Portable
Google Chrome 120
VirtualBox
Tutti gli articoli Tutte le news Tutti i download

Strumenti

Regole
Non Puoi aprire nuove discussioni
Non Puoi rispondere ai messaggi
Non Puoi allegare file
Non Puoi modificare i tuoi messaggi

Il codice vB è On
Le Faccine sono On
Il codice [IMG] è On
Il codice HTML è Off
Vai al Forum


Tutti gli orari sono GMT +1. Ora sono le: 17:01.


Powered by vBulletin® Version 3.6.4
Copyright ©2000 - 2026, Jelsoft Enterprises Ltd.
Served by www3v