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 25-10-2010, 13:48   #1
krivo
Junior Member
 
Iscritto dal: Oct 2010
Messaggi: 16
[C] Prelevare valori da una lista di adiacenza

salve, il mio problema riguarda un es. di programmazione in C, ho una lista di adiacenza, cioè un vettore di puntatori a liste concatenate, dopo aver inserito i valori nelle liste il programma li deve stampare su schermo.

ecco il sorgente:
Codice:
#include <stdio.h>
#include <stdlib.h>
#define MAX 100

/*elemento di una lista*/
struct nodo {
       int n_nodo;
       struct nodo *next;
       };
/*lista di adiacenza*/
struct nodo *Adj[MAX];
    
/*crea una lista e ci inserisce i valori*/
struct nodo *crea_lista(void){
       struct nodo *p_lista, *p;//Puntatori ad una lista
       int x, n, i;
       printf("Numero elementi nella lista: ");
       scanf("%d", &n);
       p_lista = NULL;
       printf("Inserire elementi della lista:\n");
       for(i=0; i<n; i++) {
                scanf("%d", &x);
                p = (struct nodo *)malloc(sizeof(struct nodo));//Allocazione dinamica di un elemento
                p->n_nodo = x;  //Inserisce il valore nell'elemento
                p->next = p_lista;  
                p_lista = p;  //p_lista punta alla lista creata
                }
       return(p_lista);
       }

int crea_grafo(struct nodo *lista[]){
    int i, n;
    printf("Numero dei nodi del grafo: ");
    scanf("%d", &n);
    for(i=0;i<n;i++){
        printf("Lista di adiacenza del nodo %d.\n",i);
        //Ad ogni elemento del vettore restituisce 
        //un puntatore ad una lista creata con crea_lista
        lista[i]=crea_lista();  
        }
    //Restituisce la dimensione del vettore
    return(n);
    }

int main(){
    struct nodo *a; //Puntatore ad una lista
    int c, i=0, n, j=0; 
    n = crea_grafo(&Adj[MAX]); //Memorizza i valori nella lista di adiacenza
    printf("lista[%d]:\n",i);
    //prende un elemento della vettore Adj, ad esempio il primo
    //che corrisponde ad un puntatore ad una lista
    //e ne stampa i valori della lista
    for(a=*Adj; a=NULL; a->next){//fin quando c'è un elemento scorre la lista
         c=a->n_nodo; //assegna il valore n_nodo di ogni elemento della lista in una variabile
         printf("elemento %d: %d\n",i, c); // stampa la variabile
         i=i+1;
         }
    getchar();
    getchar();

}
penso che la parte di scorrimento e stampa della lista sia giusta (quella in grassetto) ma evidentemente non è così.

vi prego di scusarmi se non ho rispettato le regole, potete eliminare il post

ho cercato di rendere il codice più leggibile possibile, se non capite qualcosa chiedete
krivo è offline   Rispondi citando il messaggio o parte di esso
Old 25-10-2010, 15:21   #2
GioVesas
Member
 
Iscritto dal: Jun 2004
Città: Pecetto
Messaggi: 73
Io scriverei cosi:

Codice:
 a=*Adj;
 while (a !=NULL)
 {
         c=a->n_nodo; //assegna il valore n_nodo di ogni elemento della lista in una variabile
         printf("elemento %d: %d\n",i, c); // stampa la variabile
         i=i+1;
         a=a->next;
  }
__________________
Gianni
GioVesas è offline   Rispondi citando il messaggio o parte di esso
Old 25-10-2010, 16:03   #3
krivo
Junior Member
 
Iscritto dal: Oct 2010
Messaggi: 16
ti ringrazio ma anche seguendo il tuo suggerimento i valori non vengono stampati, sebbene il codice non fa una piega.

altre idee?
krivo è offline   Rispondi citando il messaggio o parte di esso
Old 25-10-2010, 16:26   #4
GioVesas
Member
 
Iscritto dal: Jun 2004
Città: Pecetto
Messaggi: 73
Codice:
    n = crea_grafo(&Adj[MAX]); //Memorizza i valori nella lista di adiacenza
deve essere
    n = crea_grafo(&Adj[0]); //Memorizza i valori nella lista di adiacenza
altrimenti punti fuori tabella.
Inoltre nella funzione crea_lista non sono sicuro di come gestisci next
non dovrebbe essere il pPrevious->next = pNuovo?
__________________
Gianni
GioVesas è offline   Rispondi citando il messaggio o parte di esso
Old 25-10-2010, 16:41   #5
krivo
Junior Member
 
Iscritto dal: Oct 2010
Messaggi: 16
il programma finiva subito perchè puntavo direttamente all'ultimo elemento, quindi non aveva elementi da stampare, ora invece funziona, grazie GioVegas!

comunque quello che dici è giusto solo che invece io creo un nuovo elemento e questo punta all'inizio della lista, quindi lo aggiungo in cima e non in fondo
krivo è 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...
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...
Pirateria audiovisiva: la Guardia di Fin...
Ubisoft conferma due nuovi Far Cry in sv...
Chi vincerà il Festival di Sanrem...
G42 e Cerebras portano in India un super...
Offerte aggiornate del weekend Amazon: 7...
4 MacBook Air in offerta e scende a 939€...
Chrome cambia il tuo modo di lavorare: o...
Minimo storico iPhone 17 su Amazon: 909€...
USA, incriminati tre ingegneri della Sil...
Xbox: Phil Spencer lascia dopo 38 anni, ...
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: 04:41.


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