Torna indietro   Hardware Upgrade Forum > Software > Programmazione

Ecovacs Deebot X12 OmniCyclone: lava grazie a FocusJet
Ecovacs Deebot X12 OmniCyclone: lava grazie a FocusJet
Il nuovo Deebot X12 OmniCyclone abbina un sistema di raccolta dello sporco senza sacchetto, un rullo di lavaggio esteso e la tecnologia FocusJet per intervenire più efficacemente sulle macchie più persistenti. Un robot completo e preciso che aiuta a tenere puliti i pavimenti di casa con il minimo sforzo
Narwal Flow 2: la pulizia di casa con un mocio a nastro
Narwal Flow 2: la pulizia di casa con un mocio a nastro
Narwal Flow 2 implementa un mocio a nastro che esegue una pulizia dettagliata del pavimento di casa, in abbinamento ad un potente motore di aspirazione della polvere: un prodotto ideale per gestire in autonomia e con grande efficacia le necessità di pulizia dei pavimenti di casa
Tastiera gaming MSI GK600 TKL: switch hot-swap, display LCD e tre modalità wireless
Tastiera gaming MSI GK600 TKL: switch hot-swap, display LCD e tre modalità wireless
MSI FORGE GK600 TKL WIRELESS: switch lineari hot-swap, tripla connettività, display LCD e 5 strati di fonoassorbimento. Ottima in gaming, a 79,99 euro
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


Ecovacs Deebot X12 OmniCyclone: lava grazie a FocusJet Ecovacs Deebot X12 OmniCyclone: lava grazie a Fo...
Narwal Flow 2: la pulizia di casa con un mocio a nastro Narwal Flow 2: la pulizia di casa con un mocio a...
Tastiera gaming MSI GK600 TKL: switch hot-swap, display LCD e tre modalità wireless Tastiera gaming MSI GK600 TKL: switch hot-swap, ...
DJI Osmo Pocket 4: la gimbal camera tascabile cresce e ha nuovi controlli fisici DJI Osmo Pocket 4: la gimbal camera tascabile cr...
Sony INZONE H6 Air: il primo headset open-back di Sony per giocatori Sony INZONE H6 Air: il primo headset open-back d...
Falsa partenza per l'app della verifica ...
PRAGMATA è un successo: raggiunto...
Privacy, il Garante multa Poste Italiane...
Aramco ribalta il concetto di 'ibrido'. ...
Apple cambia tutto: Tim Cook lascia il t...
Dyson Supersonic Travel: il nuovo asciug...
Huawei punta sul canale europeo: per il ...
Ubuntu 26.04: le GPU guadagnano il 17% i...
La Commissione UE registra l'iniziativa ...
SSD troppo cari? La soluzione alla crisi...
Anteprima mondiale Hyundai IONIQ 3: segm...
Fintool sbarca su Microsoft 365: arrivan...
Hanno chiesto 1 dollaro per salvare un M...
Arriva AgentExchange, il marketplace di ...
Blizzard fa chiudere Turtle WoW: perché ...
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:45.


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