Torna indietro   Hardware Upgrade Forum > Software > Programmazione

Roborock Saros 20: il robot preciso e molto sottile
Roborock Saros 20: il robot preciso e molto sottile
Il nuovo robot di Roborock per l'aspirazione della polvere e il lavaggio dei pavimenti spicca per immediatezza d'uso e per l'efficacia dell'azione, grazie anche a un ridotto sviluppo in altezza. Saros 20 integra un motore da ben 36.000Pa di potenza e un sistema di lavaggio a due panni rotanti, con bracci estensibili e un sistema di navigazione molto preciso.
ASUS ROG Kithara: quando HIFIMAN incontra il gaming con driver planari da 100mm
ASUS ROG Kithara: quando HIFIMAN incontra il gaming con driver planari da 100mm
ASUS e HIFIMAN uniscono le forze per creare ROG Kithara, cuffie gaming con driver magnetici planari da 100mm, design open-back e microfono MEMS full-band. Una proposta che ambisce a coniugare fedeltà per audiofili e performance ludiche, disponibili a 319 euro
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
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 Saros 20: il robot preciso e molto sottile Roborock Saros 20: il robot preciso e molto sott...
ASUS ROG Kithara: quando HIFIMAN incontra il gaming con driver planari da 100mm ASUS ROG Kithara: quando HIFIMAN incontra il gam...
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...
TSMC, capacità produttiva a 2 nan...
Resident Evil Requiem: il lancio è...
Xiaomi 17 in arrivo: parte il conto alla...
Rapidus incassa 1,7 miliardi di dollari ...
Parcheggi in città senza pensieri...
IA e crisi sistemica: perché tre ...
Le migliori offerte Amazon del weekend, ...
Offerte smartphone Amazon: sono 12 fra c...
Lefant a 139€ o roborock a 149€? Solo 10...
160 campi da calcio di server: l'impatto...
210€ risparmiate su MacBook Air in offer...
Google Pixel 10a, il prezzo scende subit...
Lockheed Martin testa l'AI sull'F-35 Lig...
La missione NASA Lunar Trailblazer &egra...
Gli astronauti di Artemis II utilizzeran...
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: 13:25.


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