Torna indietro   Hardware Upgrade Forum > Software > Programmazione

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
OVHcloud Summit 2025: le novità del cloud europeo tra sovranità, IA e quantum
OVHcloud Summit 2025: le novità del cloud europeo tra sovranità, IA e quantum
Abbiamo partecipato all'OVHcloud Summit 2025, conferenza annuale in cui l'azienda francese presenta le sue ultime novità. Abbiamo parlato di cloud pubblico e privato, d'intelligenza artificiale, di computer quantistici e di sovranità. Che forse, però, dovremmo chiamare solo "sicurezza"
Tutti gli articoli Tutte le news

Vai al Forum
Rispondi
 
Strumenti
Old 25-02-2005, 17:01   #1
Ancosen
Member
 
L'Avatar di Ancosen
 
Iscritto dal: Jan 2003
Città: Roma
Messaggi: 183
[C] Alberi binari maledetti

Dunque ecco qua un albero binario (struttura odiosa davvero) vi pongo subito il problema e vi posto il codice che ho elaborato io, la funzione Preorder che dovrebbe sostituire alla radice la somma dei sottoalberi è sbagliata... Cmq ecco il testo completo...

"Progettare un programma C che
legge da stdin un albero binario in preordine e stampa
in preordine su sdtout l'albero ottenuto sostituendo
l'etichetta di ogni nodo r con la somma delle etichette
del sottoalbero con radice r."

#include<stdio.h>
#include<stdlib.h>

struct treenode
{
struct treenode *leftptr;
int data;
struct treenode *rightptr;
};
typedef struct treenode TreeNode;
typedef TreeNode *TreeNodeptr;

TreeNodeptr insertnormal();
int PreOrder(TreeNodeptr treeptr);

int main()
{
TreeNodeptr Tree = NULL;
Tree = insertnormal();
PreOrder(Tree);
}

TreeNodeptr insertnormal()
{
int f,value;
TreeNodeptr newPtr = NULL;
scanf("%d %d", &f, &value);
newPtr = (TreeNode*) malloc(sizeof(TreeNode));
if ((newPtr)== NULL)
{
return;
}
else
{
newPtr->data = value;
switch(f)
{
case 0:
newPtr->leftptr = NULL;
newPtr->rightptr = NULL;
break;

case 1:
newPtr->leftptr = insertnormal();
newPtr->rightptr = NULL;
break;

case 2:
newPtr->leftptr = insertnormal();
newPtr->rightptr = insertnormal();
break;
}
return(newPtr);
}
}
int PreOrder(TreeNodeptr treeptr)
{
TreeNodeptr left = NULL;
TreeNodeptr right = NULL;
right = treeptr->rightptr;
left = treeptr->leftptr;
int i = 0;
if(treeptr != NULL)
{
while(left != NULL && right != NULL)
{
i = PreOrder(left) + PreOrder(right);
treeptr-> data = i;
printf("%d", treeptr->data);
}
}
}
Esempio 1.

stdin:
2 0
1 7
0 11
2 9
0 13
0 22

stdout:
2 62
1 18
0 11
2 44
0 13
0 22

Grazie a chiunque mi aiuterà anche con una piccola indicazione. Secondo me è sbagliata la ricorsione però non lo so.. Non lanciate la funzione PreOrder che altrimenti vi da un loop infinito!

Ultima modifica di Ancosen : 25-02-2005 alle 17:19.
Ancosen è offline   Rispondi citando il messaggio o parte di esso
Old 25-02-2005, 17:33   #2
71104
Bannato
 
L'Avatar di 71104
 
Iscritto dal: Feb 2005
Città: Roma
Messaggi: 7029
[OT] scusate ma non resisto :D

BWUAHWUHWUAHWA Andrea Cosentino se la sta facendo sotto per l'esame di Programmazione 1 del 28 Feb all'università La Sapienza di Roma!!!
dai scherzo, in bocca al lupo!
71104 è offline   Rispondi citando il messaggio o parte di esso
Old 25-02-2005, 18:26   #3
anx721
Senior Member
 
L'Avatar di anx721
 
Iscritto dal: Oct 2002
Città: Roma
Messaggi: 1502
io non ho capito com'è rappresentato l'albero in input..qual è il figlio sinistro e quello destro di un nodo?
__________________
Sun Certified Java Programmer
EUCIP Core Level Certified

European Certification of Informatics Professionals
anx721 è offline   Rispondi citando il messaggio o parte di esso
Old 25-02-2005, 19:04   #4
71104
Bannato
 
L'Avatar di 71104
 
Iscritto dal: Feb 2005
Città: Roma
Messaggi: 7029
l'albero è da leggere in preordine, quindi il formato è come segue:

Codice:
<etichetta figlio sinistro (se esiste)>
<esistenza del figlio sx> <esistenza del figlio dx> <etichetta padre>
<etichetta figlio destro (se esiste)>
per esempio, se un albero è etichettato con la scritta "ciao" e i suoi due figli sono rispettivamente "come" e "stai", la sua rappresentazione in preordine è la seguente:

Codice:
come
1 1 ciao
stai
dove i due 1 sono dei flag che indicano l'esistenza dei figli.
71104 è offline   Rispondi citando il messaggio o parte di esso
Old 25-02-2005, 19:06   #5
71104
Bannato
 
L'Avatar di 71104
 
Iscritto dal: Feb 2005
Città: Roma
Messaggi: 7029
non vorrei però essermi confuso con l'inorder; in tal caso il formato del preorder sarebbe:

Codice:
<esistenza del figlio sx> <esistenza del figlio dx> <etichetta padre>
<etichetta figlio sinistro (se esiste)>
<etichetta figlio destro (se esiste)>
esempio:

Codice:
1 1 ciao
come
stai
71104 è offline   Rispondi citando il messaggio o parte di esso
Old 25-02-2005, 21:14   #6
Ancosen
Member
 
L'Avatar di Ancosen
 
Iscritto dal: Jan 2003
Città: Roma
Messaggi: 183
71104

Ma ci conosciamo io e te? Almeno di nome? oppure di vista?
Ancosen è offline   Rispondi citando il messaggio o parte di esso
Old 25-02-2005, 21:25   #7
anx721
Senior Member
 
L'Avatar di anx721
 
Iscritto dal: Oct 2002
Città: Roma
Messaggi: 1502
io ancora non ho capito com'è rappresentato st'albero in input
__________________
Sun Certified Java Programmer
EUCIP Core Level Certified

European Certification of Informatics Professionals
anx721 è offline   Rispondi citando il messaggio o parte di esso
Old 25-02-2005, 21:42   #8
71104
Bannato
 
L'Avatar di 71104
 
Iscritto dal: Feb 2005
Città: Roma
Messaggi: 7029
Re: 71104

Quote:
Originariamente inviato da Ancosen
Ma ci conosciamo io e te? Almeno di nome? oppure di vista?
non te lo dico
come sono dispettoso
71104 è offline   Rispondi citando il messaggio o parte di esso
Old 26-02-2005, 11:05   #9
Ancosen
Member
 
L'Avatar di Ancosen
 
Iscritto dal: Jan 2003
Città: Roma
Messaggi: 183
e dai... Stiamo andando un po' OT mi pare...
Ancosen è offline   Rispondi citando il messaggio o parte di esso
Old 26-02-2005, 12:53   #10
71104
Bannato
 
L'Avatar di 71104
 
Iscritto dal: Feb 2005
Città: Roma
Messaggi: 7029
[OT]

ok, fine dell'OT, sono uno dell'università del 1° anno; ti do un indizio: su TWiki sono famoso...
ora torniamo IT
71104 è offline   Rispondi citando il messaggio o parte di esso
Old 26-02-2005, 13:20   #11
Ancosen
Member
 
L'Avatar di Ancosen
 
Iscritto dal: Jan 2003
Città: Roma
Messaggi: 183
Ah forse ho capito... Sei quel ragazzo a cui avrebbero dovuto testare l'ultimo homework anche con i negativi?
Ancosen è offline   Rispondi citando il messaggio o parte di esso
Old 26-02-2005, 13:24   #12
Ancosen
Member
 
L'Avatar di Ancosen
 
Iscritto dal: Jan 2003
Città: Roma
Messaggi: 183
Tornando IT l'albero è letto in PreOrder, quindi faccio lo switch dei figli e creo i nodi a seconda del numero dei figli.. Il problema è la seconda parte... Mi sono allenato parecchio e ho fatto un sacco di problemi di vecchi esami del Prof...
Ancosen è offline   Rispondi citando il messaggio o parte di esso
Old 26-02-2005, 14:15   #13
anx721
Senior Member
 
L'Avatar di anx721
 
Iscritto dal: Oct 2002
Città: Roma
Messaggi: 1502
Se il problema è la seconda parte, cioè aggiornare l'etichetta di un nodo con la somma delle etichette del sottoalbero corrispondente basta fare cosi:

Codice PHP:
int aggiorna(TreeNodeptr tree){
        if(
tree == NULL)
                return 
0;
        
//sommo all'etichetta della radice le etichette del
       //sottoalbero sinistro
        
tree -> data += aggiorna(tree -> leftptr);
        
//sommo all'etichetta della radice le etichette del
       //sottoalbero destro
        
tree -> data += aggiorna(tree -> rightptr);
        return 
tree -> data;


aggiorna esegue una visita inorder dell'albero tree; dopo la visita ogni nodo r dell'albero avrà per etichetta la somma delle etichette del sottoalbero radicato in r. aggiorna ritorna l'etichetta aggiornata del nodo radice.

Dopo aver usato la funzione aggiorna, ti basta fare una visita in preorder dell'albero per stamparlo
__________________
Sun Certified Java Programmer
EUCIP Core Level Certified

European Certification of Informatics Professionals
anx721 è offline   Rispondi citando il messaggio o parte di esso
Old 26-02-2005, 15:04   #14
71104
Bannato
 
L'Avatar di 71104
 
Iscritto dal: Feb 2005
Città: Roma
Messaggi: 7029
ultimo OT

Quote:
Originariamente inviato da Ancosen
Ah forse ho capito... Sei quel ragazzo a cui avrebbero dovuto testare l'ultimo homework anche con i negativi?
indovinato!
piace anche a me cazzeggiare su HwUpgrade
e poi di tanto in tanto si trova anche qualcosa di utile
71104 è offline   Rispondi citando il messaggio o parte di esso
Old 26-02-2005, 17:43   #15
/\/\@®¢Ø
Bannato
 
L'Avatar di /\/\@®¢Ø
 
Iscritto dal: Jul 2000
Città: Malo (VI)
Messaggi: 1000
Re: [C] Alberi binari maledetti

Quote:
Originariamente inviato da Ancosen
Dunque ecco qua un albero binario (struttura odiosa davvero) vi pongo subito il problema e vi posto il codice che ho elaborato io, la funzione Preorder che dovrebbe sostituire alla radice la somma dei sottoalberi è sbagliata... Cmq ecco il testo completo...

"Progettare un programma C che
legge da stdin un albero binario in preordine e stampa
in preordine su sdtout l'albero ottenuto sostituendo
l'etichetta di ogni nodo r con la somma delle etichette
del sottoalbero con radice r."
Se guardi bene non ti e' mai chiesto di costruire l'albero, ma solo di leggerlo in preordine e scriverlo in preordine.
Per ogni nodo tu hai bisogno solo del nuovo valore dei figli (oltre che del valore del nodo stesso), e il risultato serve solo al padre.
Tralasciando la stampa del risultato, questo vuol dire che la funzione chiesta dall'esercizio non e' altro che la seguente (codice stile python per brevita'):

Codice:
def tree():
  """Leggi il prossimo nodo dalla linea di comando, procedi con
      eventuali figli e ritorna la somma totale"""
  sons,value = leggi_la_prossima_linea()
  for n in range(0,sons):
    value = value + tree()
  return value
E per la stampa del risultato ?
Se fosse richiesto in ordine postfisso, sarebbe molto semplice, basterebbe stampare il risultato non appena calcolato prima di ritornarlo:

Codice:
def tree():
  """Leggi il prossimo nodo dalla linea di comando, procedi con
      eventuali figli e ritorna la somma totale"""
  sons,value = leggi_la_prossima_linea()
  for n in range(0,sons):
    value =  value + tree()
  print sons,value
  return value
In questo pero' modo la radice verrebbe stampata per ultima e non per prima. A noi serve il contrario, per cui invece che stamparla direttamente, la memorizziamo in una struttura dati (che sara' pero' piu' semplice di un albero binario ), e alla fine stampiamo i valori trovati in ordine inverso.
Anche convertito in C, non dovresti andare oltre alle 25-30 linee di codice.

Ultima modifica di /\/\@®¢Ø : 26-02-2005 alle 17:45.
/\/\@®¢Ø è offline   Rispondi citando il messaggio o parte di esso
Old 27-02-2005, 11:39   #16
Ancosen
Member
 
L'Avatar di Ancosen
 
Iscritto dal: Jan 2003
Città: Roma
Messaggi: 183
Re: ultimo OT

Quote:
Originariamente inviato da 71104
indovinato!
piace anche a me cazzeggiare su HwUpgrade
e poi di tanto in tanto si trova anche qualcosa di utile
Si, in effetti è divertente! E poi c'è un sacco di gente in gamba, spesso mi aggiorno qua anche sui nuovi dispositivi hardware! A te come è andato lab? che esercizi c'erano? Ho visto che i risultati del 14 non sono ancora usciti...

Grazie a tutti quelli che mi hanno risposto
Ancosen è offline   Rispondi citando il messaggio o parte di esso
Old 27-02-2005, 13:59   #17
71104
Bannato
 
L'Avatar di 71104
 
Iscritto dal: Feb 2005
Città: Roma
Messaggi: 7029
OTissimo

Quote:
Originariamente inviato da Ancosen
Si, in effetti è divertente! E poi c'è un sacco di gente in gamba, spesso mi aggiorno qua anche sui nuovi dispositivi hardware! A te come è andato lab? che esercizi c'erano? Ho visto che i risultati del 14 non sono ancora usciti...
ehm... veramente siamo ancora OT, cmq laboratorio mi è andata male, c'è stata na storia... il giorno della prova non riuscivo a loggarmi perché il mio account improvvisamente non funzionava +!!! alla fine si è capito che era un problema di KDE e sono riuscito a loggarmi su Gnome, ma tra una cosa e l'altra ci abbiamo messo 3 quarti d'ora!!! e l'esame era già iniziato e io morale della storia ho avuto solo un'ora di tempo anziché 2
non ci sono parole, è stata una cosa vergognosa; ho anche chiesto al prof se vista la situazione poteva cancellare il mio nome e permettermi di tornare all'appello successivo, ma niente
morale della storia sono riuscito a svolgere solo 3 esercizi su 9, però forse non è neanche detto che sia andata tanto male perché il migliore che c'era è riuscito a farne 4 e uno sa che è sbagliato
forse un 24 riesco ad accaparrarmelo...
cmq ti do una dritta: il tronci dice che all'esame è possibile portarsi dei pezzi di codice fatti a casa; tu fatti TUTTI gli esercizi del 25 e portati quelli, perché i nostri erano estremamente simili
se vogliamo continuare la discussione andiamo su TWiki
ciao
71104 è offline   Rispondi citando il messaggio o parte di esso
Old 27-02-2005, 17:03   #18
Ancosen
Member
 
L'Avatar di Ancosen
 
Iscritto dal: Jan 2003
Città: Roma
Messaggi: 183
ok per twiki.
Ancosen è offline   Rispondi citando il messaggio o parte di esso
Old 27-02-2005, 22:33   #19
mpattera
Senior Member
 
L'Avatar di mpattera
 
Iscritto dal: Dec 2004
Città: Parma
Messaggi: 1037
per fare la somma dei sottoalberi la soluzione più razionale sarebbe un tipo di visita in postorder cmq..
mpattera è offline   Rispondi citando il messaggio o parte di esso
 Rispondi


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...
DJI Neo 2 in prova: il drone da 160 grammi guadagna il gimbal e molto altro DJI Neo 2 in prova: il drone da 160 grammi guada...
AWS rinnova lo stack dell’IA: Trainium3,...
AWS entra nell'era degli agenti: il keyn...
Roscosmos: inventario a bordo della ISS ...
Arduino viene acquisita da Qualcomm e ca...
Un razzo spaziale Arianespace Vega C ha ...
Terra Next dà il via a Scale-Up P...
Il veicolo riutilizzabile ESA Space Ride...
Un Mousepad per mirare meglio: uno youtu...
Tokyo Electron sotto accusa: Taiwan cont...
L'ESA sta cercando alternative all'utili...
iliad TOP 250 PLUS e TOP 300 PLUS: valan...
FRITZ! a Sicurezza 2025: connessioni WiF...
I 18enni di oggi non fanno più la...
Super offerte Apple: iPhone 16e a 529€ e...
Torres EVT arriva in Italia con listino ...
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: 07:42.


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