|
|||||||
|
|
|
![]() |
|
|
Strumenti |
|
|
#1 |
|
Member
Iscritto dal: Jul 2006
Messaggi: 51
|
[C] Esercizio strutture e puntatori.
Premetto che NON scrivo per ottenere la soluzione dell'esercizio, non mi servirebbe a niente.
Sia data la struttura typedef struct elemento {int lung; char *stringa; struct elemento*next} lista;, che rappresenta un elemento di una lista di stringhe, dove il campo intero lung rappresenta la lunghezza della stringa (escluso il carattere di terminazione). Si scriva una funzione lista *trasponiNonOrdinato(lista *lis); che, dato il puntatore lis al primo elemento della lista, restituisca una nuova lista dello stesso tipo, dove la i-esima stringa della nuova lista `e ottenuta concatenando l’elemento i-esimo delle stringhe in lis, quando presente. Ad esempio, se le stringhe puntate da lis sono {solam, proroe, poi, mihon, ab}, la lista risultante dovrà contenere le stringhe {sppma, oroib, loih, aro, mon, e}, e le rispettive lunghezze (escluso il carattere di terminazione). Questo è l'esercizio. So sicuramente che la lista che devo restituire conterrà un numero di stringhe pari alla lunghezza della stringa che avrà il campo 'lung' maggiore. La mia difficoltà ora è questa: siccome devo creare una nuova lista che conterrà le stringhe che devo comporre come la traccia mi dice, come faccio a creare questa nuova lista (dove ci devo mettere le nuove stringhe ) e a creare il puntatore al primo elemento della lista? Lo so che per voi sembrerà una cosa facile, ma non ho mai lavorato con le strutture quindi sono in difficoltà. Grazie a chi mi aiuterà.
__________________
http://risorsefree.netsons.org/ |
|
|
|
|
|
#2 |
|
Senior Member
Iscritto dal: Feb 2004
Messaggi: 1454
|
devi usare la memoria dinamica; se sei in c ti serve la malloc, in c++ c'è anche la new.
|
|
|
|
|
|
#3 | |
|
Member
Iscritto dal: Jul 2006
Messaggi: 51
|
Quote:
Quindi come se stessi allocando un array di int o di double (solo che qui quando vado ad allocare non uso un int/double ma la variabila ''lista'') ? Una volta che ho creato una lista con la malloc (il numero di elementi dipenderà dalla lunghezza del carattere massimo, posso utilizzare la sintassi che uso per esempio quando ho un array di interi (ad esempio se ho un array chiamato a di n elementi l'i-esimo elemento è a[i-1]) ??
__________________
http://risorsefree.netsons.org/ Ultima modifica di klarence : 30-05-2008 alle 02:04. |
|
|
|
|
|
|
#4 |
|
Senior Member
Iscritto dal: Feb 2004
Messaggi: 1454
|
sì per gli array la sintassi è la solita.
quando fai l'allocazione non devi usare una variabile, ma il tipo dell'oggetto da allocare. |
|
|
|
|
|
#5 | |
|
Member
Iscritto dal: Jul 2006
Messaggi: 51
|
Quote:
Ok grazie
__________________
http://risorsefree.netsons.org/ |
|
|
|
|
|
|
#6 |
|
Member
Iscritto dal: Jul 2006
Messaggi: 51
|
Faccio qui la domanda per non aprire sempre 800 topic. Ho il puntatore al primo elemento della lista, so che ogni elemento punta a quello successivo e so che l'ultimo elemento punta a NULL. Per alcuni esercizi mi farebbe comodo contare il numero di elementi della lista.
Va bene questo codice? for(i=lista; ;i=i->next){ if(i->next==NULL){ numero_elementi=numero_elementi+1; break;} else{ numero_elementi=numero_elementi+1;}}
__________________
http://risorsefree.netsons.org/ |
|
|
|
|
| Strumenti | |
|
|
Tutti gli orari sono GMT +1. Ora sono le: 20:20.




















