Torna indietro   Hardware Upgrade Forum > Software > Programmazione

Mad Catz M.M.O. 7+: lo stesso DNA del R.A.T. 8+ ADV, ma con molti più pulsanti
Mad Catz M.M.O. 7+: lo stesso DNA del R.A.T. 8+ ADV, ma con molti più pulsanti
Con 22 tasti, il pulsante 5D, lo Shift Mode e il sensore PixArt 3395 da 26.000 DPI, il nuovo mouse wireless di Mad Catz si rivolge in modo preciso ai giocatori di MMO e RPG. Ma chi conosce già il R.A.T. 8+ ADV si accorgerà subito di quanto i due prodotti condividano, e di dove invece divergono
Radeon RX 9070 GRE, AMD la porta in tutto il mondo | Recensione Gigabyte Gaming OC
Radeon RX 9070 GRE, AMD la porta in tutto il mondo | Recensione Gigabyte Gaming OC
Abbiamo provato la Gigabyte Radeon RX 9070 GRE Gaming OC, nuova proposta RDNA 4 che si inserisce tra GeForce RTX 5060 Ti e RTX 5070. Prestazioni solide in rasterizzazione e ray tracing, frequenze elevate grazie all'overclock di fabbrica e raffreddamento efficace: ecco come si comporta nei nostri test.
Reolink OMVI 3i WiFi: videosorveglianza più intelligente e facile da usare
Reolink OMVI 3i WiFi: videosorveglianza più intelligente e facile da usare
Con tripla lente, tracking sincronizzato, visione notturna a colori e controllo locale senza abbonamenti, la OMVI 3i WiFi porta la sicurezza domestica a un livello molto più moderno, ma senza trasformarla in un sistema complicato da installare o usare
Tutti gli articoli Tutte le news

Vai al Forum
Rispondi
 
Strumenti
Old 19-10-2001, 16:17   #1
petronella
Senior Member
 
L'Avatar di petronella
 
Iscritto dal: Feb 2001
Città: Altamura (BA)
Messaggi: 2100
Alberi n-ari

Salve a tutti,
non riesco ad implementare l'operatore insprimosottoalbero di una struttura dati albero realizzata tramite liste di figli. Qualcuno può darmi una mano?
Il linguaggio usato è il C.
Grazie a tutti,
Domenico.
petronella è offline   Rispondi citando il messaggio o parte di esso
Old 19-10-2001, 19:09   #2
cionci
Senior Member
 
L'Avatar di cionci
 
Iscritto dal: Apr 2000
Città: Vicino a Montecatini(Pistoia) Moto:Kawasaki Ninja ZX-9R Scudetti: 29
Messaggi: 53971
Che intendi per insPrimoSottoalbero ? Spiegati meglio...comè la struttura dati ? Sono liste concatenate di nodi o liste di alberi ?
cionci è offline   Rispondi citando il messaggio o parte di esso
Old 19-10-2001, 20:34   #3
petronella
Senior Member
 
L'Avatar di petronella
 
Iscritto dal: Feb 2001
Città: Altamura (BA)
Messaggi: 2100
in un array sono memorizzati tutti i nodi dell'albero ed ogni elemento dell'array è un puntatore ad una lista i cui elementi sono i figli di tale nodo .
Quindi ho un array di liste. Le informaioni relative ad ogni singolo nodo (etichetta) sono memorizzate in un altro array in corrispondenza dello stesso indice. Faccio un esempio dove l'etichetta del nodo è di tipo tipoelem (char, int, ecc ):

struct tipocella
{
indice elemento;
struct tipocella * successivo;
};
typedef struct tipocella cella;
typedef cella * lista ; // ho definito la lista

struct tipoalbero
{
lista testa[max_num_nodi]; // array di liste
tipoelem info[max_num_nodi]; // info associate ad ogni nodo
};
typedef tipoalbero albero;

la funzione :

void insprimosottoalbero(albero, albero *, nodo);

permette di fondere due alberi ed in particolare di inserire l'albero B (secondo parametro) come primo figlio del nodo (terzo parametro) dell'albero A (primo parametro).

Se vuoi ti allego il sorgente .

Ciao e grazie,
Domenico.
petronella è offline   Rispondi citando il messaggio o parte di esso
Old 19-10-2001, 22:24   #4
/\/\@®¢Ø
Bannato
 
L'Avatar di /\/\@®¢Ø
 
Iscritto dal: Jul 2000
Città: Malo (VI)
Messaggi: 1000
Spero di aver ben capito la struttura del tuo albero
allora la funzione che cerchi potrebbe essere la seguente

Per comodita suppongo che i due albero abbiano un campo in cui memorizzano il numero di nodi

void insprimosottoalbero(albero* A, albero * B, nodo)
{
// c'e' spazio ?
if ( A->size + B->size > max_num_nodi ) return;
// copiamo le liste del secondo albero nel primo
for ( int i=0 ; i< B->size ; i++ )
{
A->testa[i+A->size]=B->testa[i];
}
// gli elementi di B, che avevano indice 0 a B->size , ora hanno indice da A->size ad A->size+B->size, devo aggiornare le liste
for( int = 0 ;i< B->size ; i++ )
{
lista* l = A->testa[i+A->size];
while( l != NULL )
{
l->elemento+= A->size;
l=l->next;
}
}
// ora non ci resta che mettere la radice di B ( che ora ha indice A->size )
// come figlio del nodo indicato
lista* n = new lista;
n->elemento= A->size;
n->next=A->testa[nodo];
A->testa[nodo]=n;
// aggiorniamo la dimensione
A->size += B->size;
}



NB- Come avrai notato questo è C++, quindi dovrai fare alcune modifiche (minime)
/\/\@®¢Ø è offline   Rispondi citando il messaggio o parte di esso
Old 19-10-2001, 22:29   #5
/\/\@®¢Ø
Bannato
 
L'Avatar di /\/\@®¢Ø
 
Iscritto dal: Jul 2000
Città: Malo (VI)
Messaggi: 1000
Dimenticavo....
per pigrizia non mi sono preoccupato di copiare le liste.
Quindi l'albero inserito non e' piu' utilizzabile da se'.
Se vuoi poterlo utilizzare ancora devi crearti delle nuove liste invece che copiare e modificare le vecchie.
L'idea di base comunque rimane quella ( copia i nodi, aggiorna gli indici, collega la radice al nodo desiderato ), e non dovrebbe esserti difficile effettuare i dovuti cambiamenti.
ciao
marco
/\/\@®¢Ø è offline   Rispondi citando il messaggio o parte di esso
Old 19-10-2001, 23:13   #6
/\/\@®¢Ø
Bannato
 
L'Avatar di /\/\@®¢Ø
 
Iscritto dal: Jul 2000
Città: Malo (VI)
Messaggi: 1000
Post post scriptum
non ho provato a compilare il codice,
puo' darsi ( anzi, probabile ) che contenga errori.
Mi interessava piu' che altro spiegarti il procedimento.
/\/\@®¢Ø è offline   Rispondi citando il messaggio o parte di esso
Old 20-10-2001, 08:44   #7
petronella
Senior Member
 
L'Avatar di petronella
 
Iscritto dal: Feb 2001
Città: Altamura (BA)
Messaggi: 2100
Ok ci provo.
Grazie,
Domenico.
petronella è offline   Rispondi citando il messaggio o parte di esso
 Rispondi


Mad Catz M.M.O. 7+: lo stesso DNA del R.A.T. 8+ ADV, ma con molti più pulsanti Mad Catz M.M.O. 7+: lo stesso DNA del R.A.T. 8+ ...
Radeon RX 9070 GRE, AMD la porta in tutto il mondo | Recensione Gigabyte Gaming OC Radeon RX 9070 GRE, AMD la porta in tutto il mon...
Reolink OMVI 3i WiFi: videosorveglianza più intelligente e facile da usare Reolink OMVI 3i WiFi: videosorveglianza pi&ugrav...
Recensione Vivo X300 Ultra: fotocamera eccezionale, ma prezzo proibitivo Recensione Vivo X300 Ultra: fotocamera ecceziona...
Xiaomi 17T Pro recensione: zoom Leica 5x e batteria silicio-carbonio per l'alternativa ai top Xiaomi 17T Pro recensione: zoom Leica 5x e batte...
Vision Pro è già morto? La...
Ve lo siete perso? Smart TV UHD TCL da 6...
Tomb Raider: Legacy of Atlantis, conferm...
Eccezionale: Panasonic Lumix GH5 II con ...
Apple Design Awards 2026: c'è anc...
Nintendo conferma una nuova versione di ...
Notebook RTX Spark, in pochi potranno pe...
Dashcam 70mai 4K A810 Lite in prova: pic...
Getac ZX80: il tablet Android con displa...
Fallout 76, Infestazioni: l'esplorazione...
Per l'IA servono ancora più investimenti...
Anthropic, DeepMind e Meta assumono filo...
ASUS rientra nel mercato dei tablet Andr...
Xiaomi 18, arrivano i primi rumor: dimen...
Gli editori potranno escludere i propri ...
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: 10:14.


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