Torna indietro   Hardware Upgrade Forum > Software > Programmazione

Roborock Qrevo Curv 2 Flow: ora lava con un rullo
Roborock Qrevo Curv 2 Flow: ora lava con un rullo
Qrevo Curv 2 Flow è l'ultima novità di casa Roborock per la pulizia di casa: un robot completo, forte di un sistema di lavaggio dei pavimenti basato su rullo che si estende a seguire il profilo delle pareti abbinato ad un potente motore di aspirazione con doppia spazzola laterale
Alpine A290 alla prova: un'auto bella che ti fa innamorare, con qualche limite
Alpine A290 alla prova: un'auto bella che ti fa innamorare, con qualche limite
Abbiamo guidato per diversi giorni la Alpine A290, la prima elettrica del nuovo corso della marca. Non è solo una Renault 5 sotto steroidi, ha una sua identità e vuole farsi guidare
Recensione HONOR Magic 8 Lite: lo smartphone indistruttibile e instancabile
Recensione HONOR Magic 8 Lite: lo smartphone indistruttibile e instancabile
Abbiamo provato a fondo il nuovo Magic 8 Lite di HONOR, e per farlo siamo volati fino a Marrakech , dove abbiamo testato la resistenza di questo smartphone in ogni condizione possibile ed immaginabile. Il risultato? Uno smartphone praticamente indistruttibile e con un'autonomia davvero ottima. Ma c'è molto altro da sapere su Magic 8 Lite, ve lo raccontiamo in questa recensione completa.
Tutti gli articoli Tutte le news

Vai al Forum
Rispondi
 
Strumenti
Old 19-05-2013, 17: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 15:58.
dhabsot è offline   Rispondi citando il messaggio o parte di esso
 Rispondi


Roborock Qrevo Curv 2 Flow: ora lava con un rullo Roborock Qrevo Curv 2 Flow: ora lava con un rull...
Alpine A290 alla prova: un'auto bella che ti fa innamorare, con qualche limite Alpine A290 alla prova: un'auto bella che ti fa ...
Recensione HONOR Magic 8 Lite: lo smartphone indistruttibile e instancabile Recensione HONOR Magic 8 Lite: lo smartphone ind...
Sony WF-1000X M6: le cuffie in-ear di riferimento migliorano ancora Sony WF-1000X M6: le cuffie in-ear di riferiment...
Snowflake porta l'IA dove sono i dati, anche grazie a un accordo con OpenAI Snowflake porta l'IA dove sono i dati, anche gra...
Pokémon Rosso Fuoco e Verde Fogli...
Risparmiare con le offerte Amazon: weeke...
Gli Xiaomi 17 arrivano a fine febbraio, ...
48.000 Pa a poco più di 100€: la ...
PC più potente, meno spesa: su Amazon to...
Con 2 acquisti si ottiene il 40% di scon...
Blocco VPN in Spagna durante le partite ...
ECOVACS DEEBOT T30C OMNI GEN2 torna a 34...
Cercate uno smartphone? Ecco 7 modelli i...
Paramount non molla: Netflix è pr...
Missione Artemis II diretta verso la Lun...
Toy Story 5 arriva al cinema: è l...
Intel cambia rotta su Linux? Nuove assun...
Samsung aggiorna Bixby con One UI 8.5: p...
L'Etiopia vieta le auto a combustione: a...
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: 11:47.


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