Torna indietro   Hardware Upgrade Forum > Software > Programmazione

Antigravity A1: drone futuristico per riprese a 360° in 8K con qualche lacuna da colmare
Antigravity A1: drone futuristico per riprese a 360° in 8K con qualche lacuna da colmare
Abbiamo messo alla prova il drone Antigravity A1 capace di riprese in 8K a 360° che permette un reframe in post-produzione ad eliche ferme. Il concetto è molto valido, permette al pilota di concentrarsi sul volo e le manovre in tutta sicurezza e decidere con tutta tranquillità come gestire le riprese. La qualità dei video, tuttavia, ha bisogno di uno step in più per essere competitiva
Sony Alpha 7 V, anteprima e novità della nuova 30fps, che tende la mano anche ai creator
Sony Alpha 7 V, anteprima e novità della nuova 30fps, che tende la mano anche ai creator
Dopo oltre 4 anni si rinnova la serie Sony Alpha 7 con la quinta generazione, che porta in dote veramente tante novità a partire dai 30fps e dal nuovo sensore partially stacked da 33Mpixel. L'abbiamo provata per un breve periodo, ecco come è andata dopo averla messa alle strette.
realme GT 8 Pro Dream Edition: prestazioni da flagship e anima racing da F1
realme GT 8 Pro Dream Edition: prestazioni da flagship e anima racing da F1
realme e Aston Martin Aramco F1 Team si sono (ri)unite dando alla vita un flagship con chip Snapdragon 8 Elite Gen 5 e design esclusivo ispirato alle monoposto di Formula 1. La Dream Edition introduce la nuova colorazione Lime Essence abbinata al tradizionale Aston Martin Racing Green, decorazioni intercambiabili personalizzate e una confezione a tema F1, intorno a uno smartphone dall'ottima dotazione tecnica con batteria da 7000mAh ricaricabile a 120W e isola fotografica intercambiabile
Tutti gli articoli Tutte le news

Vai al Forum
Rispondi
 
Strumenti
Old 31-07-2008, 09:32   #1
xbubbax
Senior Member
 
Iscritto dal: Apr 2007
Messaggi: 381
[C] Massimo Elemento In Un Albero Binario

Codice HTML:
int Massimo(int x, tree T)
{
    if(T!=NULL)
    {
        Massimo(x,T->SX);

        if(T->DATO>x)
        {
            x=T->DATO;
        }

        Massimo(x,T->DX);
    }
}
Come mai questo esercizio mi restituisce sempre il massimo degli elementi del sottoalbero destro e non di tutto l'albero?

Naturalmente la x all'inizio quando si entra nella funzione viene messa a 0
xbubbax è offline   Rispondi citando il messaggio o parte di esso
Old 31-07-2008, 09:58   #2
xbubbax
Senior Member
 
Iscritto dal: Apr 2007
Messaggi: 381
ho dimenticato di mettere "return x" ma non penso che cambi il risultato
xbubbax è offline   Rispondi citando il messaggio o parte di esso
Old 31-07-2008, 10:13   #3
banryu79
Senior Member
 
L'Avatar di banryu79
 
Iscritto dal: Oct 2007
Città: Padova
Messaggi: 4131
Codice:
int Massimo(int x, tree T)
{
    if(T!=NULL)
    {
        Massimo(x,T->SX);

        if(T->DATO>x)
        {
            x=T->DATO;
        }

        Massimo(x,T->DX);
    }
}
Credo che l'errore stia nel fatto che tu entri ricorsivamente nel sottoalbero di sinistra, e ad ogni nuova chiamata continui a passare tale sottoalbero finchè esso è != NULL.
Quando arrivi alla fine del ramo sinitro e non c'è più alcun sottoalbero non si verifica la condizone if(T!=NULL) e quindi la funzione ricorsiva ritorna alla chiamante precedente e così via fino a tornare nel contesto della prima invocazione (in grasetto nel codice).

A quel punto hai esaminato tutto il ramo di sinitra ma non hai ancora mai eseguito nessun controllo sul valore del dato rispetto a x; cominci a farlo solo subito dopo con
Codice:
...
f(T->DATO>x)
{
     x=T->DATO;
}
...
e quindi a questo punto memorizzi il primo valore "di sinistra" che trovi, per poi cominciare la serie di chiamate ricorsive ai sottoalberi di destra:
Codice:
...
Massimo(x,T->DX);
dove, durante l'esecuzione di ogni chiamata viene finalmente eseguito il codice
che confronta il DATO contenuto con x e, se maggiore, lo memorizza in x.
__________________

As long as you are basically literate in programming, you should be able to express any logical relationship you understand.
If you don’t understand a logical relationship, you can use the attempt to program it as a means to learn about it.
(Chris Crawford)
banryu79 è offline   Rispondi citando il messaggio o parte di esso
Old 31-07-2008, 10:29   #4
xbubbax
Senior Member
 
Iscritto dal: Apr 2007
Messaggi: 381
è possibile correggerlo oppure è sbagliato proprio l'approccio a questo esercizio?

perchè una volta il prof lo fece in un modo molto piu complicato, ovvero facendo la #define, definendo una funzione che prendeva 3 interi e ne calcolava il maggiore..
xbubbax è offline   Rispondi citando il messaggio o parte di esso
Old 31-07-2008, 11:00   #5
gugoXX
Senior Member
 
L'Avatar di gugoXX
 
Iscritto dal: May 2004
Città: Londra (Torino)
Messaggi: 3692
Quote:
Originariamente inviato da xbubbax Guarda i messaggi
è possibile correggerlo oppure è sbagliato proprio l'approccio a questo esercizio?

perchè una volta il prof lo fece in un modo molto piu complicato, ovvero facendo la #define, definendo una funzione che prendeva 3 interi e ne calcolava il maggiore..
Si puo' correggere, certo.
Io proverei cosi'.

Codice:
int Massimo(int x, tree T)
{
    int ret=-1; (-infinito se i valori possono essere negativi)
    if(T!=NULL)
    {
        int sinistro = Massimo(x,T->SX);
        int centro = t->DATO;
        int destro = Massimo(x, t->DX);
        
        ret=max(sinistro,centro);
        ret=max(ret,destro);
    }
    return ret; 
}
Ma appunto con la funzione che restituisce il massimo di 3 valori.
__________________
Se pensi che il tuo codice sia troppo complesso da capire senza commenti, e' segno che molto probabilmente il tuo codice e' semplicemente mal scritto.
E se pensi di avere bisogno di un nuovo commento, significa che ti manca almeno un test.

Ultima modifica di gugoXX : 31-07-2008 alle 11:51. Motivo: default return
gugoXX è offline   Rispondi citando il messaggio o parte di esso
Old 31-07-2008, 11:36   #6
khelidan1980
Senior Member
 
L'Avatar di khelidan1980
 
Iscritto dal: Mar 2005
Città: Morimondo city
Messaggi: 5491
Quote:
Originariamente inviato da banryu79 Guarda i messaggi
Codice:
int Massimo(int x, tree T)
{
    if(T!=NULL)
    {
        Massimo(x,T->SX);

        if(T->DATO>x)
        {
            x=T->DATO;
        }

        Massimo(x,T->DX);
    }
}
Credo che l'errore stia nel fatto che tu entri ricorsivamente nel sottoalbero di sinistra, e ad ogni nuova chiamata continui a passare tale sottoalbero finchè esso è != NULL.
Quando arrivi alla fine del ramo sinitro e non c'è più alcun sottoalbero non si verifica la condizone if(T!=NULL) e quindi la funzione ricorsiva ritorna alla chiamante precedente e così via fino a tornare nel contesto della prima invocazione (in grasetto nel codice).
ma quanto l'ultima chiamata ricorsiva ritorna alla precedente perchè ha trovato un puntatore null,dovrebbe poi continuare valutando il dato della foglia,e poi passare sul sottoalbero destro della foglia,che trova null e così via come in una normale visita simmetrica,secondo me,volendo mantenere questa impostazione, risolverebbe usando x come variabile globale
__________________
Khelidan
khelidan1980 è offline   Rispondi citando il messaggio o parte di esso
 Rispondi


Antigravity A1: drone futuristico per riprese a 360° in 8K con qualche lacuna da colmare Antigravity A1: drone futuristico per riprese a ...
Sony Alpha 7 V, anteprima e novità della nuova 30fps, che tende la mano anche ai creator Sony Alpha 7 V, anteprima e novità della ...
realme GT 8 Pro Dream Edition: prestazioni da flagship e anima racing da F1 realme GT 8 Pro Dream Edition: prestazioni da fl...
OVHcloud Summit 2025: le novità del cloud europeo tra sovranità, IA e quantum OVHcloud Summit 2025: le novità del cloud...
Un mostro da MSI: QD-OLED WQHD a 500 Hz con AI Care e DisplayPort 2.1a Un mostro da MSI: QD-OLED WQHD a 500 Hz con AI C...
La Lexus LFA ritorna, ma è elettr...
Cristiano Ronaldo entra nell'intelligenz...
Wi-Fi 7 Mesh in ogni stanza: guida defin...
Hytale evita Steam al lancio per non ric...
Ritorna il bonus elettrodomestici: ripar...
La Russia blocca Snapchat e FaceTime: 'u...
Tesla FSD ora permette di scrivere messa...
Total War festeggia 25 anni: annunciato ...
Tante offerte Amazon rinnovate: sono ott...
Tanti articoli Apple scontati su Amazon:...
JBL a prezzi super: due modelli top tra ...
Sony e Bad Robot uniscono le forze: in a...
Il MIT rivela: l'IA può sostituir...
iPhone Air va in sconto: il nuovo iPhone...
Polaroid Now Gen 3 torna di moda: la fot...
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:26.


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