Torna indietro   Hardware Upgrade Forum > Software > Programmazione

Ecovacs Deebot X12 OmniCyclone: lava grazie a FocusJet
Ecovacs Deebot X12 OmniCyclone: lava grazie a FocusJet
Il nuovo Deebot X12 OmniCyclone abbina un sistema di raccolta dello sporco senza sacchetto, un rullo di lavaggio esteso e la tecnologia FocusJet per intervenire più efficacemente sulle macchie più persistenti. Un robot completo e preciso che aiuta a tenere puliti i pavimenti di casa con il minimo sforzo
Narwal Flow 2: la pulizia di casa con un mocio a nastro
Narwal Flow 2: la pulizia di casa con un mocio a nastro
Narwal Flow 2 implementa un mocio a nastro che esegue una pulizia dettagliata del pavimento di casa, in abbinamento ad un potente motore di aspirazione della polvere: un prodotto ideale per gestire in autonomia e con grande efficacia le necessità di pulizia dei pavimenti di casa
Tastiera gaming MSI GK600 TKL: switch hot-swap, display LCD e tre modalità wireless
Tastiera gaming MSI GK600 TKL: switch hot-swap, display LCD e tre modalità wireless
MSI FORGE GK600 TKL WIRELESS: switch lineari hot-swap, tripla connettività, display LCD e 5 strati di fonoassorbimento. Ottima in gaming, a 79,99 euro
Tutti gli articoli Tutte le news

Vai al Forum
Rispondi
 
Strumenti
Old 25-05-2007, 16:16   #1
gigippa
Member
 
Iscritto dal: Apr 2007
Città: Torino
Messaggi: 95
[C] problema con strutture

Ciao a tutti. dovrei implementare una funzione lista leggi(void) che legga da tastiera e inserisca in una lista i numeri scelti dall utente fino al primo negativo(che non viene inserito).
Ritorna il puntatore al nodo di testa.
La lista deve avere memoria dinamica
La struttura del nodo è questa:
typedef struct nodo *lista;
struct nodo {
int x; /* Informazione */
lista next; /* Puntatore al nodo successivo. */
};

Qualcuno mi può aiutare???

Ultima modifica di gigippa : 25-05-2007 alle 16:22.
gigippa è offline   Rispondi citando il messaggio o parte di esso
Old 25-05-2007, 21:43   #2
sirus
Senior Member
 
Iscritto dal: Mar 2004
Messaggi: 16053
Quote:
Originariamente inviato da gigippa Guarda i messaggi
Ciao a tutti. dovrei implementare una funzione lista leggi(void) che legga da tastiera e inserisca in una lista i numeri scelti dall utente fino al primo negativo(che non viene inserito).
Ritorna il puntatore al nodo di testa.
La lista deve avere memoria dinamica
La struttura del nodo è questa:
typedef struct nodo *lista;
struct nodo {
int x; /* Informazione */
lista next; /* Puntatore al nodo successivo. */
};

Qualcuno mi può aiutare???
Inizia con il postare un algoritmo per la gestione di una lista (si tratta di una pila? si tratta di una cosa? si tratta di una semplicissima lista che non prevede rimozione?).
sirus è offline   Rispondi citando il messaggio o parte di esso
Old 26-05-2007, 01:12   #3
gigippa
Member
 
Iscritto dal: Apr 2007
Città: Torino
Messaggi: 95
Quote:
Originariamente inviato da sirus Guarda i messaggi
Inizia con il postare un algoritmo per la gestione di una lista (si tratta di una pila? si tratta di una cosa? si tratta di una semplicissima lista che non prevede rimozione?).
è una semplice lista che non prevede rimozione
gigippa è offline   Rispondi citando il messaggio o parte di esso
Old 26-05-2007, 08:07   #4
sirus
Senior Member
 
Iscritto dal: Mar 2004
Messaggi: 16053
Quote:
Originariamente inviato da gigippa Guarda i messaggi
è una semplice lista che non prevede rimozione
Allora inizia a scrivere un algoritmo, se per conto tuo oppure in seguito a delle spiegazioni sei arrivato a questo punto devi avere una minima idea di cosa tu debba fare.
sirus è offline   Rispondi citando il messaggio o parte di esso
Old 26-05-2007, 15:09   #5
gigippa
Member
 
Iscritto dal: Apr 2007
Città: Torino
Messaggi: 95
Avevo pensato a una cosa del genere ma non va

printf("Inserisci la prima lista: ");
int n=100;
int i;
int k;
for(i=0;i<n; i++)
if(k>0){
scanf("%d", L[0].x);
gigippa è offline   Rispondi citando il messaggio o parte di esso
Old 26-05-2007, 16:12   #6
sirus
Senior Member
 
Iscritto dal: Mar 2004
Messaggi: 16053
Pare che tu non abbia proprio la benché minima idea di come si gestisca una lista e neppure come si effettui l'allocazione dinamica di una elemento in memoria. Il codice qui sotto è un esempio che fa più o meno quello che ti veniva richiesto, la differenza è che lo fa senza utilizzare una funzione. A te il compito di capirlo e modificarlo opportunamente.

Codice:
#include <stdio.h>
#include <stdlib.h>

typedef struct node *element;
struct node {
    int info;
    element next;
};

int main() {
    element list = NULL;
    element insert = NULL;
    int info = 0;

    scanf("%d", &info);
    while(info >= 0) {
        if(list == NULL) {
            insert = (element)malloc(sizeof(element));
            insert->info = info;
            insert->next = NULL;
            list = insert;
        } else {
            insert->next = (element)malloc(sizeof(element));
            insert = insert->next;
            insert->info = info;
            insert->next = NULL;
        }
        scanf("%d", &info);
    }

    return(0);
}
sirus è offline   Rispondi citando il messaggio o parte di esso
Old 28-05-2007, 10:58   #7
gigippa
Member
 
Iscritto dal: Apr 2007
Città: Torino
Messaggi: 95
Grazie per l' aiuto! Adesso stavo provando a fare una funzione void stampa(lista L) che stampi tutti i numeri contenuti nella lista
La mia idea era questa
void stampa(lista L)
{
while(L->next !=NULL)
printf("%d", L->x);
}
Ma ci sono dei problemi. Mi dai una dritta? grazie
gigippa è offline   Rispondi citando il messaggio o parte di esso
Old 28-05-2007, 11:13   #8
sirus
Senior Member
 
Iscritto dal: Mar 2004
Messaggi: 16053
Quote:
Originariamente inviato da gigippa Guarda i messaggi
Grazie per l' aiuto! Adesso stavo provando a fare una funzione void stampa(lista L) che stampi tutti i numeri contenuti nella lista
La mia idea era questa
void stampa(lista L)
{
while(L->next !=NULL)
printf("%d", L->x);
}
Ma ci sono dei problemi. Mi dai una dritta? grazie
La dritta è che con un codice simile non leggi l'ultimo elemento della lista ma il concetto è molto simile a quello che hai esposto.
sirus è offline   Rispondi citando il messaggio o parte di esso
Old 28-05-2007, 13:59   #9
gigippa
Member
 
Iscritto dal: Apr 2007
Città: Torino
Messaggi: 95
A parte quello quando faccio girare il programma mi si inchioda! Legge correttamente ma quando si tratta di stampare va in crash
gigippa è offline   Rispondi citando il messaggio o parte di esso
Old 28-05-2007, 15:31   #10
Volutomitra
Member
 
Iscritto dal: Feb 2006
Messaggi: 134
Quote:
Originariamente inviato da gigippa Guarda i messaggi
A parte quello quando faccio girare il programma mi si inchioda! Legge correttamente ma quando si tratta di stampare va in crash
Va in crash o non esce mai dal while?
Volutomitra è offline   Rispondi citando il messaggio o parte di esso
Old 28-05-2007, 16:15   #11
gigippa
Member
 
Iscritto dal: Apr 2007
Città: Torino
Messaggi: 95
va in crash. Mi dice che si è verificato un errore e che l' applicazione verrà chiusa
gigippa è offline   Rispondi citando il messaggio o parte di esso
Old 28-05-2007, 16:26   #12
Volutomitra
Member
 
Iscritto dal: Feb 2006
Messaggi: 134
Quote:
Originariamente inviato da gigippa Guarda i messaggi
va in crash. Mi dice che si è verificato un errore e che l' applicazione verrà chiusa
La mia era una domanda mirata. Se fosse possibile succederebbero entrambe le cose. Occhio alla partenza. Cosa succede se la lista è vuota? E perché non si esce dal while?
Volutomitra è offline   Rispondi citando il messaggio o parte di esso
Old 28-05-2007, 16:42   #13
gigippa
Member
 
Iscritto dal: Apr 2007
Città: Torino
Messaggi: 95
Quote:
Originariamente inviato da Volutomitra Guarda i messaggi
La mia era una domanda mirata. Se fosse possibile succederebbero entrambe le cose. Occhio alla partenza. Cosa succede se la lista è vuota? E perché non si esce dal while?
Se la lista è vuota capita la stessa cosa
gigippa è offline   Rispondi citando il messaggio o parte di esso
Old 28-05-2007, 17:07   #14
Volutomitra
Member
 
Iscritto dal: Feb 2006
Messaggi: 134
Quote:
Originariamente inviato da gigippa Guarda i messaggi
Se la lista è vuota capita la stessa cosa
Appunto. Se la lista vuota L è NULL. Ma il primo confronto del while è L->next != NULL. In L->next può esserci qualsiasi valore. E dal while non siesce mai perché il valore di L->next è sempre lo stesso.
Volutomitra è offline   Rispondi citando il messaggio o parte di esso
Old 28-05-2007, 17:38   #15
gigippa
Member
 
Iscritto dal: Apr 2007
Città: Torino
Messaggi: 95
Quote:
Originariamente inviato da Volutomitra Guarda i messaggi
Appunto. Se la lista vuota L è NULL. Ma il primo confronto del while è L->next != NULL. In L->next può esserci qualsiasi valore. E dal while non siesce mai perché il valore di L->next è sempre lo stesso.
Quindi devo cambiare la condizione del while. Se però metto L->x != NULL non cambia nulla
gigippa è offline   Rispondi citando il messaggio o parte di esso
Old 28-05-2007, 19:08   #16
sirus
Senior Member
 
Iscritto dal: Mar 2004
Messaggi: 16053
Prova con:
Codice:
...
while(list != NULL) {
    printf("%d", list->info);
    list = list->next;
}
...
in questo modo eviti il problema della lista vuota e ti blocchi quando raggiungi l'ultimo elemento della lista che si deve sempre concludere con NULL, cosa che succede se hai sviluppato la funzione di scrittura partendo da quel codice che ho postato pochi post sopra.

PS: attento al passaggio per indirizzo del parametro list della funzione di lettura, ogni modifica che si fa nella funzione si ripercuote sul parametro.
sirus è offline   Rispondi citando il messaggio o parte di esso
Old 28-05-2007, 22:43   #17
gigippa
Member
 
Iscritto dal: Apr 2007
Città: Torino
Messaggi: 95
Cambiando le variabili che tu hai messo con quelle del mio programma ho messo così
void stampa(lista L)
{
while(L!= NULL)
printf("%d", L->x);
L = L->next;
}
Ma non funziona lo stesso
gigippa è offline   Rispondi citando il messaggio o parte di esso
Old 29-05-2007, 08:07   #18
sirus
Senior Member
 
Iscritto dal: Mar 2004
Messaggi: 16053
Menomale che non funziona... ti mancano delle parentesi {} .
Oltretutto non hai neppure seguito il consiglio che ti avevo dato di copiare il valore del parametro che passi alla funzione in una variabile locale della funzione.
sirus è offline   Rispondi citando il messaggio o parte di esso
 Rispondi


Ecovacs Deebot X12 OmniCyclone: lava grazie a FocusJet Ecovacs Deebot X12 OmniCyclone: lava grazie a Fo...
Narwal Flow 2: la pulizia di casa con un mocio a nastro Narwal Flow 2: la pulizia di casa con un mocio a...
Tastiera gaming MSI GK600 TKL: switch hot-swap, display LCD e tre modalità wireless Tastiera gaming MSI GK600 TKL: switch hot-swap, ...
DJI Osmo Pocket 4: la gimbal camera tascabile cresce e ha nuovi controlli fisici DJI Osmo Pocket 4: la gimbal camera tascabile cr...
Sony INZONE H6 Air: il primo headset open-back di Sony per giocatori Sony INZONE H6 Air: il primo headset open-back d...
Huawei punta sul canale europeo: per il ...
Ubuntu 26.04: le GPU guadagnano il 17% i...
La Commissione UE registra l'iniziativa ...
SSD troppo cari? La soluzione alla crisi...
Anteprima mondiale Hyundai IONIQ 3: segm...
Fintool sbarca su Microsoft 365: arrivan...
Hanno chiesto 1 dollaro per salvare un M...
Arriva AgentExchange, il marketplace di ...
Blizzard fa chiudere Turtle WoW: perché ...
Claude Desktop e la modifica silenziosa ...
Blue Origin ha mostrato gli interni del ...
Linux alla pari di Windows in gioco: con...
Il rientro del secondo stadio del razzo ...
Il controller ufficiale Microsoft per Xb...
DJI Power 1000 Mini: la power station da...
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:32.


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