D4rkAng3l
09-03-2005, 09:55
Ma sono veramente così incasinate o sono io ad essere stupido...
Da quello che ho capito le liste sono strutture ricorsive ovvereo una struttura che contiene uno o più elementi dato e un puntatore ad un'altra struttura dello stesso tipo e così via finchè non si raggiunge l'ultimo nodo che contiene un puntatore di tipo NULL...ho capito bene?
Stò facendo un programma preso dal libro abbastanza lungo e ho dei dubbi sulla prima parte...ve la posto....
#include <stdio.h>
#include <stdlib.h>
struct listNode{
char data;
struct listNode *nextPtr;
}; // Dichiaro un tipo struct listNode di una struttura ricorsiva
typedef struct listNode LISTNODE;
typedef LISTNODE *LISTNODEPTR;
/* Prototipi delle funzioni che saranno usate nel programma /*
void insert(LISTNODEPTR *, char);
char delete(LISTNODEPTR *, char);
int isEmpty(LISTNODEPTR);
void printList(LISTNODEPTR);
void instructions(void);
int main(){
blablabla
.............
.............
.............
return 0;
}
La cosa che per il momento mi è meno chiara è perchè fà i due typedef:
typedef struct listNode LISTNODE;
questo vabbè dice che quando scriverò LISTNODE è come se scrivessi structi listNode e dovrebbe essere solo per comodità...giusto?
typedef LISTNODE *LISTNODEPTR;
ma questo che significa?perchè lo fà?!!?
Per favore aiutatemi stò in crisi.....
Grazie
Andrea
Da quello che ho capito le liste sono strutture ricorsive ovvereo una struttura che contiene uno o più elementi dato e un puntatore ad un'altra struttura dello stesso tipo e così via finchè non si raggiunge l'ultimo nodo che contiene un puntatore di tipo NULL...ho capito bene?
Stò facendo un programma preso dal libro abbastanza lungo e ho dei dubbi sulla prima parte...ve la posto....
#include <stdio.h>
#include <stdlib.h>
struct listNode{
char data;
struct listNode *nextPtr;
}; // Dichiaro un tipo struct listNode di una struttura ricorsiva
typedef struct listNode LISTNODE;
typedef LISTNODE *LISTNODEPTR;
/* Prototipi delle funzioni che saranno usate nel programma /*
void insert(LISTNODEPTR *, char);
char delete(LISTNODEPTR *, char);
int isEmpty(LISTNODEPTR);
void printList(LISTNODEPTR);
void instructions(void);
int main(){
blablabla
.............
.............
.............
return 0;
}
La cosa che per il momento mi è meno chiara è perchè fà i due typedef:
typedef struct listNode LISTNODE;
questo vabbè dice che quando scriverò LISTNODE è come se scrivessi structi listNode e dovrebbe essere solo per comodità...giusto?
typedef LISTNODE *LISTNODEPTR;
ma questo che significa?perchè lo fà?!!?
Per favore aiutatemi stò in crisi.....
Grazie
Andrea