Torna indietro   Hardware Upgrade Forum > Software > Programmazione

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
Snowflake porta l'IA dove sono i dati, anche grazie a un accordo con OpenAI
Snowflake porta l'IA dove sono i dati, anche grazie a un accordo con OpenAI
Snowflake ha presentato diverse novità per la sua piattaforma legate all'intelligenza artificiale. Quella forse più eclatante è una collaborazione con OpenAI, ma non mancano diverse nuove funzionalità che rendono la piattaforma più flessibile e in grado di rispondere meglio alle esigenze in continuo cambiamento delle aziende
Sistema Mesh Roamii BE Pro: il Wi-Fi 7 secondo MSI
Sistema Mesh Roamii BE Pro: il Wi-Fi 7 secondo MSI
Con velocità teoriche fino a 11 Gbps, gestione tramite app intelligente e protezione avanzata dei dispositivi, Roamii BE Pro porta il Wi‑Fi 7 tri‑band nelle abitazioni più esigenti. Un sistema Wi-Fi Mesh proposto da MSI allo scopo di garantire agli utenti una rete fluida e continua capace di sostenere streaming 8K, gaming competitivo e le applicazioni moderne più esigenti in termini di banda
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


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...
Recensione HUAWEI Mate X7: un foldable ottimo, ma restano i soliti problemi Recensione HUAWEI Mate X7: un foldable ottimo, m...
Nioh 3: souls-like punitivo e Action RPG Nioh 3: souls-like punitivo e Action RPG
Zscaler Threat Report 2026: l'adozione d...
Claude AI minaccia omicidi e ricatti qua...
Dentro la gara: a Milano Cortina 2026 i ...
Samsung Display presenta QD-OLED Penta T...
KONAMI torna con "Silent Hill: Town...
Rende il citofono smart a 44,99€: Ring I...
ThunderX3 XTC, la sedia da ufficio che s...
Mercy, Mission Impossible, Aronofsky: il...
Project Windless: il nuovo action in esc...
Saros: mostrato il gameplay del gioco de...
God of War: Sons of Sparta annunciato e ...
John Wick torna in un nuovo videogioco a...
MADE chiude il 2025 con 59 partner e 250...
007 First Light: allo State of Play un n...
Gli iPhone su Amazon costano meno che su...
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: 20:26.


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