Torna indietro   Hardware Upgrade Forum > Software > Programmazione

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.
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
Sony WF-1000X M6: le cuffie in-ear di riferimento migliorano ancora
Sony WF-1000X M6: le cuffie in-ear di riferimento migliorano ancora
WF-1000X M6 è la sesta generazione di auricolare in-ear sviluppata da Sony, un prodotto che punta a coniugare facilità di utilizzo con una elevata qualità di riproduzione dei contenuti audio e una cura nella riduzione del rumore ambientale che sia da riferimento
Tutti gli articoli Tutte le news

Vai al Forum
Rispondi
 
Strumenti
Old 04-09-2010, 13:29   #1
-hide-
Senior Member
 
L'Avatar di -hide-
 
Iscritto dal: Sep 2008
Città: Messina
Messaggi: 991
[C] Adiacenza nei grafi

Il mio problema è riscontrato all'interno di questo esercizio:
Quote:
Un dispositivo di rete è composto dalle seguenti strutture: una coda circolare (in grado di memorizzare N pacchetti), un grafo G=(V,E) (rappresentato mediante liste di adiacenza), due pile (pila A e pila B). Ogni pacchetto è caratterizzato da un indirizzo_mittente (un intero comperso tra 0 e V-1), un indirizzo_destinatario (un intero compreso tra 0 e V-1) ed un campo payload di tipo generico struct data.
Compito del dispositivo è quello di smistare i pacchetti prelevandoli (mediante un ciclo infinito) dalla coda circolare ed inserendoli nelle pile in base alla topologiia del grafo. In particolare, i pacchetti in cui il mittente è un vicino del destinatario devono essere inoltrati sulla pila A, tutti gli altri sulla pila B.
Descrivere la struttura dati ed implementare le funzioni principali in lungiaggio C.
Ciò su cui vorrei un aiuto è la parte in grassetto. Non riesco a scoprire i vicini di un particolare nodo (in tal caso mittente), perché in una struttura del tipo:
Codice:
for (n = adj[mittente]; n != NULL; n = n->next) {
   /* qualcosa qui dentro */
}
n = n->next non fa cambiare il nodo sul quale si ricercano i vicini?
__________________

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 04-09-2010, 14:24   #2
oNaSsIs
Member
 
L'Avatar di oNaSsIs
 
Iscritto dal: Apr 2007
Messaggi: 182
Il problema potrebbe essere risolto in diversi modi, però secondo me una soluzione semplice potrebbe essere aggiungere un campo hop intero all'interno della struttura pacchetto, ammesso che l'esercizio conceda la possibilità di modificare tale struttura. In questo modo utilizzi il campo hop come un contatore che conta il numero di salti, ossia il numero di nodi che il pacchetto attraversa, se hop=1 e il pacchetto è arrivato a destinazione significa che il destinatario è proprio un vicino.
Considera che il campo hop esiste anche nella realtà, si chiama TTL (Time To Live) e viene utilizzato per evitare cicli infiniti da parte di un pacchetto.

In alternativa ti basta fare una scansione della lista di adiacenza del mittente prima di "spedire" il pacchetto.
Però la prima soluzione secondo me è più flessibile, perchè ti permette di avere anche ulteriori informazioni come ad esempio la distanza tra due nodi...
oNaSsIs è offline   Rispondi citando il messaggio o parte di esso
Old 04-09-2010, 15:34   #3
-hide-
Senior Member
 
L'Avatar di -hide-
 
Iscritto dal: Sep 2008
Città: Messina
Messaggi: 991
Quote:
Originariamente inviato da oNaSsIs Guarda i messaggi
Il problema potrebbe essere risolto in diversi modi, però secondo me una soluzione semplice potrebbe essere aggiungere un campo hop intero all'interno della struttura pacchetto, ammesso che l'esercizio conceda la possibilità di modificare tale struttura. In questo modo utilizzi il campo hop come un contatore che conta il numero di salti, ossia il numero di nodi che il pacchetto attraversa, se hop=1 e il pacchetto è arrivato a destinazione significa che il destinatario è proprio un vicino.
Considera che il campo hop esiste anche nella realtà, si chiama TTL (Time To Live) e viene utilizzato per evitare cicli infiniti da parte di un pacchetto.
Puoi farmi un esempio dell'utilizzo del campo hop, perché credo che il mio problema sia proprio nel capire quando effettua un salto.
__________________

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 04-09-2010, 19:54   #4
oNaSsIs
Member
 
L'Avatar di oNaSsIs
 
Iscritto dal: Apr 2007
Messaggi: 182
Naturalmente il campo di ogni pacchetto sarà inizializzato a 0 e verrà incrementato ad ogni salto, ossia ogni volta che passi da un nodo all'altro e questa operazione tu la esegui proprio nel momento in cui scrivi:
Codice:
n = n->next
oNaSsIs è offline   Rispondi citando il messaggio o parte di esso
Old 05-09-2010, 11:15   #5
Don[ITA]
Senior Member
 
L'Avatar di Don[ITA]
 
Iscritto dal: Jul 2006
Città: Bergamo
Messaggi: 401
Forse ho capito male io, ma non basta fare così??
Codice:
coda Q;
pila A, B;
while(true) {
    bool inserito := false;
    pacchetto P := dequeue(Q);    //estraggo il pacchetto dalla coda
    int adjp := adj[P.mittente];     //prendo gli adiacenti del mittente
    for(i := 0 to adjp.length)         //scorro gli adiacenti del mittente
        if(P.destinatario == adjp[i]) then    //se il destinatario è tra gli adiacenti del mittente
            enqueue(P, A)    //lo inserisco in A
            inserito := true;
            break;
    if(!inserito) then
        enqueue(P, B)    //altrimenti lo inserisco in B
    inserito := false;
} //fine ciclo infinito
Ovviamente è "pseudocodice" ma dovresti capirlo abbastanza facilmente.
Questa è solo una bozza per rendere l'idea, ma se è corretta dovresti anche essere in grado di sistemarla a tuo piacimento

Spero di aver capito bene!!!

Cya
__________________
iMac 27" 5K
Don[ITA] è offline   Rispondi citando il messaggio o parte di esso
Old 05-09-2010, 11:31   #6
oNaSsIs
Member
 
L'Avatar di oNaSsIs
 
Iscritto dal: Apr 2007
Messaggi: 182
Questa è l'alternativa che avevo suggerito nel primo post:
Quote:
Originariamente inviato da oNaSsIs Guarda i messaggi
In alternativa ti basta fare una scansione della lista di adiacenza del mittente prima di "spedire" il pacchetto.
Però la prima soluzione secondo me è più flessibile, perchè ti permette di avere anche ulteriori informazioni come ad esempio la distanza tra due nodi...
Però guardando il tuo pseudocodice forse l'esercizio è più semplice di quello che io pensavo, perchè ero convinto che comunque bisognava simulare l'intero cammino,ma se non è così allora consiglio anche io questa soluzione, in alternativa se invece il cammino va effettivamente simulato reputo la prima migliore...
oNaSsIs è offline   Rispondi citando il messaggio o parte di esso
Old 05-09-2010, 11:38   #7
tuccio`
Senior Member
 
Iscritto dal: Apr 2010
Città: Frosinone
Messaggi: 416
Quote:
Originariamente inviato da -hide- Guarda i messaggi
Il mio problema è riscontrato all'interno di questo esercizio:


Ciò su cui vorrei un aiuto è la parte in grassetto. Non riesco a scoprire i vicini di un particolare nodo (in tal caso mittente), perché in una struttura del tipo:
Codice:
for (n = adj[mittente]; n != NULL; n = n->next) {
   /* qualcosa qui dentro */
}
n = n->next non fa cambiare il nodo sul quale si ricercano i vicini?
se adj[mittente], come immagino, è la lista dei nodi adiacenti al nodo mittente.. perché dovrebbe? |:
tuccio` è offline   Rispondi citando il messaggio o parte di esso
 Rispondi


Recensione HONOR Magic 8 Lite: lo smartphone indistruttibile e instancabile Recensione HONOR Magic 8 Lite: lo smartphone ind...
Alpine A290 alla prova: un'auto bella che ti fa innamorare, con qualche limite Alpine A290 alla prova: un'auto bella che ti fa ...
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...
Sistema Mesh Roamii BE Pro: il Wi-Fi 7 secondo MSI Sistema Mesh Roamii BE Pro: il Wi-Fi 7 secondo M...
Apple AirDrop su Android: dopo Pixel 10,...
Upgrade PC senza spendere una fortuna: G...
Sistema di sblocco alla iPhone anche su ...
29 offerte Amazon, rinnovate: in 2 minut...
Offerte imperdibili su lavatrici e asciu...
Kingdom Come: Deliverance 2 arriva su Ga...
Il Texas fa causa a TP-Link: accuse di m...
Google annuncia le date ufficiali di I/O...
Nuovo rilancio di Amazon Haul: -20% se s...
NVIDIA azzera la partecipazione in Arm H...
Crimson Desert può diventare GOTY...
HONOR Magic 8 Lite ufficiale: il nuovo s...
Apple prepara occhiali smart, un ciondol...
WordPress integra un assistente AI che m...
La FIA ha controllato a caldo il motore ...
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: 12:28.


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