Torna indietro   Hardware Upgrade Forum > Software > Programmazione

Zeekr X e 7X provate: prezzi, autonomia fino a 615 km e ricarica in 13 minuti
Zeekr X e 7X provate: prezzi, autonomia fino a 615 km e ricarica in 13 minuti
Zeekr sbarca ufficialmente in Italia con tre modelli elettrici premium, X, 7X e 001, distribuiti da Jameel Motors su una rete di 52 punti vendita già attivi. La Zeekr X parte da 39.900 euro, la 7X da 54.100: piattaforma a 800V, chip Snapdragon di ultima generazione, ricarica ultraveloce e un'autonomia dichiarata fino a 615 km WLTP. Le prime consegne sono previste a metà aprile
Marathon: arriva il Fortnite hardcore
Marathon: arriva il Fortnite hardcore
Marathon è il titolo multiplayer competitivo del momento. Ecco quali sono le caratteristiche di gioco principali, insieme alle nostre prime considerazioni dopo qualche "run" nell'extraction shooter di Bungie
HP Imagine 2026: abbiamo visto HP IQ all’opera, ecco cosa può (e non può) fare
HP Imagine 2026: abbiamo visto HP IQ all’opera, ecco cosa può (e non può) fare
A New York HP ha messo al centro della scena HP IQ, la piattaforma di IA locale da 20 miliardi di parametri. L’abbiamo vista in funzione: è uno strumento che funziona, pensato per un target specifico, con vantaggi reali e limiti altrettanto evidenti
Tutti gli articoli Tutte le news

Vai al Forum
Rispondi
 
Strumenti
Old 01-10-2005, 22:23   #1
TorpedoBlu
Senior Member
 
L'Avatar di TorpedoBlu
 
Iscritto dal: Sep 2003
Città: Milano
Messaggi: 4623
urgente C alberi ternari!!!

devo mettere dei percorsi di nodi della mia struttura in un albero ternario, questo albero rappresenta i possibili cammini dal nodo start al nodo end.

Codice:
typedef int polline;

typedef int prato;

/*key : indice della posizione del fiore sul piano*/
struct key{
	int X;
	int Y;
	};

typedef struct key key;


/*albero binario: rappresenta i punti del piano*/
struct searchtree {
	prato id_prato;
	polline raccolto;
	key chiave;
	struct searchtree *left, *right, *up;
}; 

typedef struct searchtree searchtree;

/*campo : rappresenta un insieme di prati che hanno punti in comune*/
struct field{
	int id_campo;
	int id_prato;
	struct field *next;
	};

typedef struct field field;

/*lista di campi*/
field *PRATO_FIORITO;

struct routetree{
	polline totale;
	key chiave;
	struct routetree  *left, *right, *center, *up;
};

typedef struct routetree routetree;

routetree *CAMMINI;
routetree *createroutetree(searchtree *start){
	routetree *q = malloc(sizeof(routetree));
	q->left=q->right=q->center=NULL;
	q->totale=start->raccolto;
	q->chiave=start->chiave;
	return q;
}

int checkstep(key *step, searchtree *end){
	int deltax=(abs)(end->chiave.X - step->X);
	int deltay=(end->chiave.Y - step->Y);
	if(deltay>=deltax)
		return 1;
	return 0;
}

routetree *buildroutetree(searchtree *piano, routetree *cammini, searchtree *end){
			searchtree *searchtree_tmp;
			key *key_tmp;
			if(isMin(cammini->chiave,end->chiave)>0){
				key_tmp->X=cammini->chiave.X-1;
				key_tmp->Y=cammini->chiave.Y+1;
				if(searchtree_tmp=itsearch(piano, *key_tmp)){
					if(checkstep(key_tmp, end)){
						cammini->left=malloc(sizeof(routetree));
						cammini->left->up=cammini;
						cammini->left->chiave=searchtree_tmp->chiave;
						cammini->left->totale=searchtree_tmp->raccolto+cammini->totale;
						cammini->left->left=buildroutetree(piano, cammini->left, end);
						cammini->left->center=buildroutetree(piano, cammini->left, end);
						cammini->left->right=buildroutetree(piano, cammini->left, end);
					}
					else
						cammini->left=NULL;
				}
				else
				cammini->left=NULL;
				
				key_tmp->X=cammini->chiave.X;
				key_tmp->Y=cammini->chiave.Y+1;
				if(searchtree_tmp=itsearch(piano, *key_tmp)){
					if(checkstep(key_tmp, end)){
						cammini->center=malloc(sizeof(routetree));
						cammini->center->up=cammini;
						cammini->center->chiave=searchtree_tmp->chiave;
						cammini->center->totale=searchtree_tmp->raccolto+cammini->totale;
						cammini->center->left=buildroutetree(piano, cammini->center, end);
						cammini->center->center=buildroutetree(piano, cammini->center, end);
						cammini->center->right=buildroutetree(piano, cammini->center, end);
					}
					else
						cammini->center=NULL;
				}
				else
					cammini->center=NULL;
				
				key_tmp->X=cammini->chiave.X+1;
				key_tmp->Y=cammini->chiave.Y+1;
				if(searchtree_tmp=itsearch(piano, *key_tmp)){
					if(checkstep(key_tmp, end)){
						cammini->right=malloc(sizeof(routetree));
						cammini->right->up=cammini;
						cammini->right->chiave=searchtree_tmp->chiave;
						cammini->right->totale=searchtree_tmp->raccolto+cammini->totale;
						cammini->right->left=buildroutetree(piano, cammini->right, end);
						cammini->right->center=buildroutetree(piano, cammini->right, end);
						cammini->right->right=buildroutetree(piano, cammini->right, end);
					}
					else
						cammini->right=NULL;
				}
				else
					cammini->right=NULL;				
			}		
	return cammini;
}
questi li spezzoni di codice, ho cercato di creare il primo nodo con il metodo createroutetree() e poi riempirlo ricorsivamente con build routetree()

lo so fa schifo, se qualcuno mi posta il codice per costruire un albero ternario gli offro una birra a Milano (anche 2)
__________________
Ho trattato con : lahiri, czame, RC, allXXX, dfruggeri, JMM, Paperone, xej, Pappez, iperfly, Red81, Playmake, ryan78, Rob66, XP2200, Peach1200, faberjack, Stewie82, supermario_bros, hft500, Axelscorpio, pipes lee, Piccolospazio, RohanKish, miki66, kabira85
TorpedoBlu è offline   Rispondi citando il messaggio o parte di esso
Old 02-10-2005, 13:19   #2
TorpedoBlu
Senior Member
 
L'Avatar di TorpedoBlu
 
Iscritto dal: Sep 2003
Città: Milano
Messaggi: 4623
panico panico, probabilmente gli alberi ternari sono una cazzata....

Dijkstra, per usare questo algoritmo come faccio? nel senso io mio albero binario è ordinato in base alla chiave (X,Y)

ma ad esempio per andare da 0,0 a 2,2 se il cammino esiste esso è per forza 0,0-1,1-2,2

la mia ape si può muovere solo in alto ed in diagonale alta (chiaramente se esistono tutti i nodi che compongono il cammino)

se ci sono + cammini prendo il cammino con il quantitativo di polline maggiore.

ma come si applica Dijkstra ad un albero binario? e che modifiche devo fare??? i valori di polline eventualmente negativi danno problemi???
__________________
Ho trattato con : lahiri, czame, RC, allXXX, dfruggeri, JMM, Paperone, xej, Pappez, iperfly, Red81, Playmake, ryan78, Rob66, XP2200, Peach1200, faberjack, Stewie82, supermario_bros, hft500, Axelscorpio, pipes lee, Piccolospazio, RohanKish, miki66, kabira85
TorpedoBlu è offline   Rispondi citando il messaggio o parte di esso
 Rispondi


Zeekr X e 7X provate: prezzi, autonomia fino a 615 km e ricarica in 13 minuti Zeekr X e 7X provate: prezzi, autonomia fino a 6...
Marathon: arriva il Fortnite hardcore Marathon: arriva il Fortnite hardcore
HP Imagine 2026: abbiamo visto HP IQ all’opera, ecco cosa può (e non può) fare HP Imagine 2026: abbiamo visto HP IQ all’opera, ...
PNY RTX 5080 Slim OC, sembra una Founders Edition ma non lo è PNY RTX 5080 Slim OC, sembra una Founders Editio...
Wi-Fi 7 con il design di una vetta innevata: ecco il nuovo sistema mesh di Huawei Wi-Fi 7 con il design di una vetta innevata: ecc...
I robot aspirapolvere ora in offerta su ...
L'Exynos 2600 a 2 nm di Samsung consuma ...
I 2 portatili migliori di tutta Amazon: ...
Tornano le offerte sui Kindle base, vers...
NVIDIA App si aggiorna: arriva DLSS 4.5 ...
Claude Code: il codice sorgente esposto ...
Recensione POCO X8 Pro: è lui lo ...
Il primo dissipatore a liquido di Noctua...
Opera Neon abilita il protocollo MCP: l'...
Dyson Clean+Wash Hygiene: lava e pulisce...
NVIDIA investe 2 miliardi in Marvell: pa...
Le GPU come garanzia bancaria: CoreWeave...
KeeneticOS si aggiorna alla versione 5: ...
Regno Unito avvia indagine su Microsoft:...
Disney vuole comprare Epic Games e Fortn...
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: 08:12.


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