Torna indietro   Hardware Upgrade Forum > Software > Programmazione

Xiaomi 15T Pro, è lui il nuovo best buy? La recensione
Xiaomi 15T Pro, è lui il nuovo best buy? La recensione
Dopo il recente lancio della serie Xiaomi 15T di Monaco, vi parliamo oggi della versione più performante della nuova famiglia, ovvero Xiaomi 15 T Pro. Vi raccontiamo la nostra prova nel dettaglio, spiegando perché a questo prezzo e in questa fascia, questo smartphone ha davvero senso tenerlo in seria considerazione.
Acer TravelMate P6 14 AI: il Copilot+ PC sotto il chilo per il professionista in movimento
Acer TravelMate P6 14 AI: il Copilot+ PC sotto il chilo per il professionista in movimento
Acer ha ampliato la sua offerta professionale con il TravelMate P6 14 AI, un notebook ultraleggero e robusto pensato per chi lavora in mobilità. Certificato Copilot+ PC, combina design premium, autonomia elevata e piattaforma Intel Core Ultra Serie 2 con funzionalità AI, garantendo sicurezza, affidabilità e produttività per l'utenza business moderna.
ASUS NUC 15 Pro e NUC 15 Pro+, mini PC che fondono completezza e duttilità
ASUS NUC 15 Pro e NUC 15 Pro+, mini PC che fondono completezza e duttilità
NUC 15 Pro e NUC 15 Pro+ sono i due nuovi mini-PC di casa ASUS pensati per uffici e piccole medie imprese. Compatti, potenti e pieni di porte per la massima flessibilità, le due proposte rispondono in pieno alle esigenze attuali e future grazie a una CPU con grafica integrata, accompagnata da una NPU per la gestione di alcuni compiti AI in locale.
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


Xiaomi 15T Pro, è lui il nuovo best buy? La recensione Xiaomi 15T Pro, è lui il nuovo best buy? ...
Acer TravelMate P6 14 AI: il Copilot+ PC sotto il chilo per il professionista in movimento Acer TravelMate P6 14 AI: il Copilot+ PC sotto i...
ASUS NUC 15 Pro e NUC 15 Pro+, mini PC che fondono completezza e duttilità ASUS NUC 15 Pro e NUC 15 Pro+, mini PC che fondo...
Cybersecurity: email, utenti e agenti IA, la nuova visione di Proofpoint Cybersecurity: email, utenti e agenti IA, la nuo...
Hisense A85N: il ritorno all’OLED è convincente e alla portata di tutti Hisense A85N: il ritorno all’OLED è convi...
Offerte super su Amazon: Blink Mini e Ou...
iPhone 16 ancora disponibile a 699€ su A...
Torna a 179€ il mini PC con Ryzen 5, 16G...
Due droni Amazon si sono schiantati cont...
Apple cambia idea? Basta visori, per il ...
Il padrino dell'intelligenza artificiale...
Western Digital: hard disk da 44 TB pron...
Connettori 12V-2x6 delle GPU NVIDIA peri...
SiPearl Athena1: il processore europeo p...
Spotify ascolta gli utenti: ecco come es...
Fine delle auto nuove svendute come usat...
La sonda spaziale cinese Tianwen-2 (dire...
Disney Plus, prezzi in aumento anche per...
Inversion Arc: la navicella spaziale per...
Il Regno Unito ha chiesto (ancora) ad Ap...
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: 08:02.


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