Torna indietro   Hardware Upgrade Forum > Software > Programmazione

Motorola edge 70: lo smartphone ultrasottile che non rinuncia a batteria e concretezza
Motorola edge 70: lo smartphone ultrasottile che non rinuncia a batteria e concretezza
Motorola edge 70 porta il concetto di smartphone ultrasottile su un terreno più concreto e accessibile: abbina uno spessore sotto i 6 mm a una batteria di capacità relativamente elevata, un display pOLED da 6,7 pollici e un comparto fotografico triplo da 50 MP. Non punta ai record di potenza, ma si configura come alternativa più pragmatica rispetto ai modelli sottili più costosi di Samsung e Apple
Display, mini PC, periferiche e networking: le novità ASUS al CES 2026
Display, mini PC, periferiche e networking: le novità ASUS al CES 2026
Sono molte le novità che ASUS ha scelto di presentare al CES 2026 di Las Vegas, partendo da una gamma di soluzioni NUC con varie opzioni di processore passando sino agli schermi gaming con tecnologia OLED. Il tutto senza dimenticare le periferiche di input della gamma ROG e le soluzioni legate alla connettività domestica
Le novità ASUS per il 2026 nel settore dei PC desktop
Le novità ASUS per il 2026 nel settore dei PC desktop
Molte le novità anticipate da ASUS per il 2026 al CES di Las Vegas: da schede madri per processori AMD Ryzen top di gamma a chassis e ventole, passando per i kit di raffreddamento all in one integrati sino a una nuova scheda video GeForce RTX 5090. In sottofondo il tema dell'intelligenza artificiale con una workstation molto potente per installazioni non in datacenter
Tutti gli articoli Tutte le news

Vai al Forum
Rispondi
 
Strumenti
Old 06-03-2011, 15:29   #1
-hide-
Senior Member
 
L'Avatar di -hide-
 
Iscritto dal: Sep 2008
Città: Messina
Messaggi: 991
[C] Grafi: ritorna tutti i cammini semplici

Un compito d'esame presenta questo quesito:
Quote:
Si scriva una funzione, in linguaggio C, che preso in ingresso un grafo G=(V,E) e due vertici a, b appartenenti a V, ritorni l'insieme di tutti i cammini semplici da a -> b. Si utilizzi, per realizzare l'algoritmo, la tecnica del backtracking.

NOTA: Un cammino si dice semplice se composto da nodi distinti.
Ho immediatamente pensato di iniziare da un altro esercizio, già da me svolto, in cui bisogna far tornare il primo cammino semplice che si viene ad incontrare. Posto qui di seguito il codice:
Codice:
void pathsearch (struct graph *ADJ[], int DIM, int a, int b, struct lista *L, int *visited[], int *trovato) {
   struct graph *temp;
   visited[a] = 1;
   insTail (L,a);
   if (a==b) {
      *trovato = 1;
      return;
   }
   for (temp=ADJ[a]; temp!=NULL; temp=temp->next)
      if (!visited[temp->v])
         pathsearch (ADJ, V, a, b, L, visited, trovato);
   if (!(*trovato)) {
      delTail (L);
      visited[a] = 0;
   }
}
Se non capite o volete che implementi anche le strutture dati dite pure.
Avevo pensato bastasse aggiungere un IF dopo l'ultimo che, alternativamente ad esso, non eliminasse l'elemento dalla coda ma non mi convince.
Suggerimenti?!
__________________

PC/HTPC: Mac Mini 3,1 late 2009 | My Book Studio 2TB | LG M237WD monitor/tv | Logitech Z4 | Apple Magic Mouse | Apple Wireless Keyboard | Apple Remote
Mobile: Samsung Galaxy Wonder i8150 cm9
LinkedIn

Ultima modifica di -hide- : 11-03-2011 alle 10:37.
-hide- è offline   Rispondi citando il messaggio o parte di esso
Old 06-03-2011, 23:46   #2
tuccio`
Senior Member
 
Iscritto dal: Apr 2010
Città: Frosinone
Messaggi: 416
Codice:
   if (!(*trovato)) {
      delTail (L);
      visited[a] = 0;
   }
eliminarlo dalla coda è corretto, ma, mettendo visited[a] a 0, rischi di andare a visitare di nuovo il nodo se ci ripassi, rifacendo il ciclo che ovviamente sarà infruttuoso, credo sia meglio lasciarlo a 1

comunque anche così dovrebbe terminare l'algoritmo

per il resto, mi sembra corretto, cos'ha che non va?
tuccio` è offline   Rispondi citando il messaggio o parte di esso
Old 07-03-2011, 18:19   #3
-hide-
Senior Member
 
L'Avatar di -hide-
 
Iscritto dal: Sep 2008
Città: Messina
Messaggi: 991
Quote:
Originariamente inviato da tuccio` Guarda i messaggi
Codice:
   if (!(*trovato)) {
      delTail (L);
      visited[a] = 0;
   }
eliminarlo dalla coda è corretto, ma, mettendo visited[a] a 0, rischi di andare a visitare di nuovo il nodo se ci ripassi, rifacendo il ciclo che ovviamente sarà infruttuoso, credo sia meglio lasciarlo a 1
L'ho inserito perché proprio quel flag impostato ad 1 non mi permetteva di tornare su un nodo, che era per l'appunto il b. Ho provato questo codice su un nodo connesso non orientato da me inventato. Posso dare un'altra occhiata ma se non ricordo male è proprio quell'aggiunta che mi permetteva di chiudere correttamente il programma.

Quote:
Originariamente inviato da tuccio` Guarda i messaggi
comunque anche così dovrebbe terminare l'algoritmo
per il resto, mi sembra corretto, cos'ha che non va?
Ma questo non è il modo per ottenere uno ed un solo cammino a -> b?! Io li vorrei avere tutti, quindi il codice mi deve permettere di tornare indietro e controllare se ci sono altre vie. Con questo codice, appena arrivo a b chiude!
__________________

PC/HTPC: Mac Mini 3,1 late 2009 | My Book Studio 2TB | LG M237WD monitor/tv | Logitech Z4 | Apple Magic Mouse | Apple Wireless Keyboard | Apple Remote
Mobile: Samsung Galaxy Wonder i8150 cm9
LinkedIn
-hide- è offline   Rispondi citando il messaggio o parte di esso
Old 08-03-2011, 09:48   #4
tuccio`
Senior Member
 
Iscritto dal: Apr 2010
Città: Frosinone
Messaggi: 416
non è vero che arrivi a b e chiude

se avessi

Codice:
return pathsearch (ADJ, V, a, b, L, visited, trovato);
al posto delle tue chiamate ricorsive chiuderebbe tutte le chiamate precedenti quando arrivi a b

invece una volta fatto il primo return torna all'ultimo vertice (chiamiamolo v) che ti ha condotto effettivamente a b e continua a ciclare in cerca di un altro cammino che ti conduce a b

ps: sulla storia di togliere il flag hai ragione tu
tuccio` è offline   Rispondi citando il messaggio o parte di esso
Old 08-03-2011, 19:57   #5
-hide-
Senior Member
 
L'Avatar di -hide-
 
Iscritto dal: Sep 2008
Città: Messina
Messaggi: 991
Quote:
Originariamente inviato da tuccio` Guarda i messaggi
non è vero che arrivi a b e chiude

se avessi

Codice:
return pathsearch (ADJ, V, a, b, L, visited, trovato);
al posto delle tue chiamate ricorsive chiuderebbe tutte le chiamate precedenti quando arrivi a b

invece una volta fatto il primo return torna all'ultimo vertice (chiamiamolo v) che ti ha condotto effettivamente a b e continua a ciclare in cerca di un altro cammino che ti conduce a b

ps: sulla storia di togliere il flag hai ragione tu
Ho da poco provato il codice e devo ammettere che non mi è risultato corretto né nella ricerca di un solo cammino ne nella ricerca di più cammini, sia con che senza il return che tu mi hai consigliato di aggiungere.
Ora non posso ma credo che nella giornata di domani scannerizzo il mio lavoro e te lo faccio vedere per conferma perché parlare così diventa molto difficile
__________________

PC/HTPC: Mac Mini 3,1 late 2009 | My Book Studio 2TB | LG M237WD monitor/tv | Logitech Z4 | Apple Magic Mouse | Apple Wireless Keyboard | Apple Remote
Mobile: Samsung Galaxy Wonder i8150 cm9
LinkedIn
-hide- è offline   Rispondi citando il messaggio o parte di esso
Old 08-03-2011, 22:11   #6
tuccio`
Senior Member
 
Iscritto dal: Apr 2010
Città: Frosinone
Messaggi: 416
sì in realtà dovresti ritornare solo se *trovato == 1 per fare quella cosa che dici (cioè ritornare appena lo trovi), sennò continui a visitare il grafo
tuccio` è offline   Rispondi citando il messaggio o parte di esso
Old 09-03-2011, 16:44   #7
-hide-
Senior Member
 
L'Avatar di -hide-
 
Iscritto dal: Sep 2008
Città: Messina
Messaggi: 991
Ho appena terminato di lavorare sul codice inerente la ricerca di un solo cammino. Credo di aver trovato l'aggiunta vincente; la trovi in grassetto nel codice stesso.

Codice:
void pathsearch (struct graph *ADJ[], int DIM, int a, int b, struct lista *L, int *visited[], int *trovato) {
   struct graph *temp;
   visited[a] = 1;
   insTail (L,a);
   if (a==b) {
      *trovato = 1;
      return;
   }
   for (temp=ADJ[a]; temp!=NULL && !(*trovato); temp=temp->next)
      if (!visited[temp->v])
         pathsearch (ADJ, V, a, b, L, visited, trovato);
   if (!(*trovato)) {
      delTail (L);
      visited[a] = 0;
   }
}
Inoltre, per conferma, ho provveduto ad eseguire il codice su un foglio.

Provo a risolvere il problema dei più percorsi.
__________________

PC/HTPC: Mac Mini 3,1 late 2009 | My Book Studio 2TB | LG M237WD monitor/tv | Logitech Z4 | Apple Magic Mouse | Apple Wireless Keyboard | Apple Remote
Mobile: Samsung Galaxy Wonder i8150 cm9
LinkedIn

Ultima modifica di -hide- : 11-03-2011 alle 10:38.
-hide- è offline   Rispondi citando il messaggio o parte di esso
 Rispondi


Motorola edge 70: lo smartphone ultrasottile che non rinuncia a batteria e concretezza Motorola edge 70: lo smartphone ultrasottile che...
Display, mini PC, periferiche e networking: le novità ASUS al CES 2026 Display, mini PC, periferiche e networking: le n...
Le novità ASUS per il 2026 nel settore dei PC desktop Le novità ASUS per il 2026 nel settore de...
Le novità MSI del 2026 per i videogiocatori Le novità MSI del 2026 per i videogiocato...
I nuovi schermi QD-OLED di quinta generazione di MSI, per i gamers I nuovi schermi QD-OLED di quinta generazione di...
Samsung Galaxy S26 Ultra: la ricarica de...
Apple ha un nuovo partner per la sua App...
Trenitalia introduce il prezzo dinamico ...
OnePlus non si ferma più: c'&egra...
DAZN sconta il piano Full per 6 mesi, se...
L'uso dell'IA nei giochi è cancer...
Meta punta sul nucleare USA per alimenta...
Le migliori offerte Amazon del weekend: ...
La crisi dell'hardware spinge i negozi g...
Apple Watch SE 3 scontato su Amazon: il ...
Robot aspirapolvere davvero scontati: si...
DDR5 troppo cara: il passato di AMD potr...
5 sconti TOP nuovi di zecca e altre offe...
Il più venduto e apprezzato: ECOV...
Era e resta un super top di gamma: il TV...
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: 17:17.


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