Torna indietro   Hardware Upgrade Forum > Software > Programmazione

Dreame X60 Pro Ultra Complete: i bracci si estendono sempre di più
Dreame X60 Pro Ultra Complete: i bracci si estendono sempre di più
Dreame X60 Pro Ultra Complete implementa due bracci estensibili, per spazzola e moccio, che si spingono ben oltre quanto visto sino ad oggi permettendo una pulizia di casa ancor più capillare e precisa
TCL 65C8L, la recensione del SQD-Mini LED da 4400 nit misurati
TCL 65C8L, la recensione del SQD-Mini LED da 4400 nit misurati
La tecnologia SQD-Mini LED di TCL arriva sul taglio da 65 pollici con la serie C8L: 2040 zone, pannello WHVA 2.0 e un picco che alle rilevazioni delle sonde tocca i 4400 nit nel profilo Filmmaker e un HDR quasi perfetto
MSI Maestro 500 Wireless: ANC e 90 ore di autonomia a 70 euro
MSI Maestro 500 Wireless: ANC e 90 ore di autonomia a 70 euro
Wireless 2.4 GHz, Bluetooth 5.4, cancellazione attiva del rumore, design pieghevole e un'autonomia che mette in imbarazzo prodotti che costano il doppio. Le Maestro 500 non eccellono in nulla, ma offrono tutto. E a questo prezzo è difficile chiedere di più
Tutti gli articoli Tutte le news

Vai al Forum
Rispondi
 
Strumenti
Old 19-05-2013, 16:47   #1
dhabsot
Member
 
L'Avatar di dhabsot
 
Iscritto dal: May 2008
Messaggi: 116
[C] Cammini minimi su grafo non pesato

Salve a tutti, avrei bisogno di una mano con l'implementazione di un algoritmo che calcoli il cammino minimo tra i vertici su grafo non pesato.
Avevo pensato di utilizzare Dijkstra impostando il peso di ogni arco uguale a 1 (e fin qui penso di esserci), il programma l'ho finito ma solo ora mi accorgo che alcuni grafi non li "digerisce", mi spiego:

Se, ad esempio, prendessi in considerazione questo grafo:

Tutto funziona perfettamente, ogni percorso è ok...

Se invece prendo quest'altro grafo:

l'output che ottengo è:
Codice:
Percorso piu' breve tra il nodo 0 e il nodo 3:
0 -> 4 -> 2 -> 3, con il costo di 3

distanza dal nodo 0 =   0, padre del nodo 0 =  -1
distanza dal nodo 1 =   1, padre del nodo 1 =   0
distanza dal nodo 2 =   2, padre del nodo 2 =   4
distanza dal nodo 3 =   3, padre del nodo 3 =   2
distanza dal nodo 4 =   1, padre del nodo 4 =   0
Cosa assolutamente sbagliata in quanto il nodo 4 è direttamente collegato al nodo 3 e il nodo 2 non è collegato al nodo 3 (è il contrario...).

Parte del codice:

Codice:
typedef struct nodo 
{
	int 	valore,
	    	peso_arco,
	        precedente;
    	struct 	nodo *succ;
}nodo_t;

typedef struct nodo0 
{
    	int 	valore;
    	struct 	nodo0 *succ;
}nodo0_t;
Codice:
int acquisisci_grafo(nodo_t *G[])
{
  	int 	i,
	    	n;
	FILE 	*file_dati;

	file_dati = fopen("file_dati.txt",
			  "r");
	if (fscanf(file_dati,
	       "%d",
	       &n) != 1); /* Acquisizione numero vertici */

  	for (i = 0; (i < n); i++) 
	{
		int 	j,
	    		nr_nodi_adiacenti;
    		nodo_t 	*p,
	       		*testa;
	
		if (fscanf(file_dati,
	       	           "%d",
			   &nr_nodi_adiacenti) != 1); /* Numero di elementi adiacenti al nodo i */
	
    		testa = NULL;

    		for (j = 0; (j < nr_nodi_adiacenti); j++) 
    		{
			p = malloc(sizeof(nodo_t));
		
			p -> peso_arco = 1; /* Set del peso di ogni arco a 1 */

			if (fscanf(file_dati,
		       		   "%d %d",
		       		   &p -> precedente,
		       		   &p -> valore) != 1);
		
			p -> succ = testa;
		
			testa = p;
    		}
		G[i] = testa;
	}
	fclose(file_dati);

  	return(n);
}

e da file gli ho dato in input:
Codice:
5
2
0 1
0 4
1
1 2
3
4 1
4 2
4 3
0
2
3 2
3 0
Qualcuno può aiutarmi? Cosa c'è di sbagliato nell'acquisizione?
Grazie mille anticipatamente!




EDIT: Risolto, il problema era nel file che gli davo in input, corretto quello funziona tutto perfettamente!

Ultima modifica di dhabsot : 20-05-2013 alle 14:58.
dhabsot è offline   Rispondi citando il messaggio o parte di esso
 Rispondi


Dreame X60 Pro Ultra Complete: i bracci si estendono sempre di più Dreame X60 Pro Ultra Complete: i bracci si esten...
TCL 65C8L, la recensione del SQD-Mini LED da 4400 nit misurati TCL 65C8L, la recensione del SQD-Mini LED da 440...
MSI Maestro 500 Wireless: ANC e 90 ore di autonomia a 70 euro MSI Maestro 500 Wireless: ANC e 90 ore di autono...
NL-LC1 è il primo dissipatore a liquido AIO di Noctua: silenzio è la parola d'ordine NL-LC1 è il primo dissipatore a liquido A...
Boox Go 10.3 (Gen II) Lumi: il tablet e-ink con Android 15 e penna, dal prezzo super Boox Go 10.3 (Gen II) Lumi: il tablet e-ink con ...
watchOS 27 non arriverà su modell...
Apple, definiti i piani per i chip futur...
Ancora tagli nel futuro di XBOX: il caso...
Samsung Galaxy S27, il compatto potrebbe...
Sempre più IA nei videogiochi: con PUBG ...
La NASA avrebbe fermato i lavori sul mod...
Mancano pochi giorni al lancio della mis...
Prime Day in anticipo, giorno 7: tempo d...
Lo smartphone HONOR con batteria da 11.0...
Amazfit Bip 5, Active 3 Premium e Balanc...
Xiaomi potrebbe portare i suoi Pro e Pro...
Crisi delle memorie: CMF annulla il pros...
La PS6 si farà attendere: il lanc...
OnePlus non sente la crisi delle memorie...
I futuri iPhone 18 Pro potrebbero costar...
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: 18:12.


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