Torna indietro   Hardware Upgrade Forum > Software > Programmazione

Recensione vivo X300 Pro: è ancora lui il re della fotografia mobile, peccato per la batteria
Recensione vivo X300 Pro: è ancora lui il re della fotografia mobile, peccato per la batteria
vivo X300 Pro rappresenta un'evoluzione misurata della serie fotografica del produttore cinese, con un sistema di fotocamere migliorato, chipset Dimensity 9500 di ultima generazione e l'arrivo dell'interfaccia OriginOS 6 anche sui modelli internazionali. La scelta di limitare la batteria a 5.440mAh nel mercato europeo, rispetto ai 6.510mAh disponibili altrove, fa storcere un po' il naso
Lenovo Legion Go 2: Ryzen Z2 Extreme e OLED 8,8'' per spingere gli handheld gaming PC al massimo
Lenovo Legion Go 2: Ryzen Z2 Extreme e OLED 8,8'' per spingere gli handheld gaming PC al massimo
Lenovo Legion Go 2 è la nuova handheld PC gaming con processore AMD Ryzen Z2 Extreme (8 core Zen 5/5c, GPU RDNA 3.5 16 CU) e schermo OLED 8,8" 1920x1200 144Hz. È dotata anche di controller rimovibili TrueStrike con joystick Hall effect e una batteria da 74Wh. Rispetto al dispositivo che l'ha preceduta, migliora ergonomia e prestazioni a basse risoluzioni, ma pesa 920g e costa 1.299€ nella configurazione con 32GB RAM/1TB SSD e Z2 Extreme
AWS re:Invent 2025: inizia l'era dell'AI-as-a-Service con al centro gli agenti
AWS re:Invent 2025: inizia l'era dell'AI-as-a-Service con al centro gli agenti
A re:Invent 2025, AWS mostra un’evoluzione profonda della propria strategia: l’IA diventa una piattaforma di servizi sempre più pronta all’uso, con agenti e modelli preconfigurati che accelerano lo sviluppo, mentre il cloud resta la base imprescindibile per governare dati, complessità e lock-in in uno scenario sempre più orientato all’hybrid cloud
Tutti gli articoli Tutte le news

Vai al Forum
Rispondi
 
Strumenti
Old 23-01-2014, 10:27   #1
biondina
Junior Member
 
Iscritto dal: Jan 2014
Messaggi: 7
[C] problema con programmino banale in C

Ciao a tutti.
Ho un problema banale ma che non riesco proprio a risolvere.
L'esercio mi chiede:

" Il programma ha una lista collegata con puntatori, ordinata in senso crescente.
Devo scrivere la funzione che incrementa ordinatamente di 1 gli elementi della lista fino a ritrovare un elemento il cui valore incrementato è
maggiore di una soglia data in ingresso. Gli elementi a partire dal primo che supera la soglia fino all'ultimo devono essere cancellati liberando la memoria. La funzione deve restituire come valore di ritorno il numero di elementi cancellati"

Il mio problema è che se ad esempio inserisco la lista 2 4 6 8 10 12 e come soglia inserisco valore 8 (presente nella lista) mi ritorna il numero di cancellazioni è 3 che è giusto; ma se inserisco valore 7 (che non c'è nella lista) mi ritorna un valore tipo 229134. Perchè?

Sotto riporto il programma

#include <stdio.h>

#include <stdlib.h>

#include <memory.h>

struct list {

int value;

struct list * next_ptr;

};

void init( struct list ** ptrptr );

void visit( struct list * ptr );

void pre_insert( struct list ** ptrptr, int value );

void ord_insert(struct list ** ptrptr, int value);

int camb_list(struct list*ptrptr,int thres);

int delete_list_el (struct list**ptrptr);

void init( struct list ** ptrptr ){

*ptrptr = NULL;

}

void visit( struct list * ptr )

/* visita della lista*/

{

while ( ptr != NULL ) {

printf( "%d ", ptr->value );

ptr = ptr->next_ptr;

}

}

void pre_insert( struct list ** ptrptr, int value )

/* inserisce in testa*/

{

struct list * tmp_ptr;

tmp_ptr = *ptrptr;

*ptrptr = (struct list *) malloc( sizeof(struct list));

(*ptrptr)->value = value;

(*ptrptr)->next_ptr = tmp_ptr;

}

void ord_insert(struct list ** ptrptr, int value)

/* inserisce in ordine*/

{ while(*ptrptr!=NULL && (*ptrptr)->value<value)

{ptrptr=&((*ptrptr)->next_ptr);

}

pre_insert(ptrptr,value);

}

int camb_list (struct list*ptrptr,int thres)

/*incrementa valori della lista per 1, fino a trovare uno >= di soglia. se trova un elemento > lo cancella dalla lista */

{ int num_canch;

while (ptrptr!=NULL && (ptrptr)->value<=thres)

{ (ptrptr)->value=(ptrptr)->value+1;

if ((ptrptr)->value>=thres){

num_canch=delete_list_el(&ptrptr);

}

else

ptrptr=(ptrptr)->next_ptr;

}

return num_canch;

}
biondina è offline   Rispondi citando il messaggio o parte di esso
Old 23-01-2014, 10:54   #2
Daniels118
Senior Member
 
L'Avatar di Daniels118
 
Iscritto dal: Jan 2014
Messaggi: 852
Dov'è la funzione delete_list_el?
Daniels118 è offline   Rispondi citando il messaggio o parte di esso
Old 23-01-2014, 10:57   #3
biondina
Junior Member
 
Iscritto dal: Jan 2014
Messaggi: 7
Quote:
Originariamente inviato da Daniels118 Guarda i messaggi
Dov'è la funzione delete_list_el?
non mi ha inserito tutto. ecco il resto:

int delete_list_el(struct list**ptrptr)
/*cancellazione*/
{
struct list*tmp;
int num_canch;
num_canch=0;
while(*ptrptr!=NULL){
tmp=*ptrptr;
*ptrptr=(*ptrptr)->next_ptr;
num_canch++;
free(tmp);
}
return num_canch;
}



int main (){

int value;
int thres;
int i;
int cancellati;
cancellati =0;
int e;
e=1;
struct list *list_ptr;
init( &list_ptr );

while (e==1){

printf( "\nInserisci valori della lista:\n");
for(i=0;i<10; i++){
scanf( "%d", &value );
ord_insert( &list_ptr, value);
}

printf( "\n\nLista inserita: " );
visit( list_ptr );

printf("\n\nInserisci numero di soglia: ");
scanf("%d",&thres);

cancellati=camb_list(list_ptr,thres);

printf("\n\nNumero di elementi cancellati: ");
printf("%d",cancellati);

printf("\n\nSe vuoi finire il programma premi il tasto 0 ");
scanf("%d",&e);

}

}
biondina è offline   Rispondi citando il messaggio o parte di esso
Old 23-01-2014, 11:02   #4
sottovento
Senior Member
 
L'Avatar di sottovento
 
Iscritto dal: Nov 2005
Città: Texas
Messaggi: 1722
Codice:
int camb_list (struct list*ptrptr,int thres) /*incrementa valori della lista per 1, fino a trovare uno >= di soglia. se trova un elemento > lo cancella dalla lista */
{
    int num_canch;
    while (ptrptr!=NULL && (ptrptr)->value<=thres)
    {
        (ptrptr)->value=(ptrptr)->value+1;
        if ((ptrptr)->value>=thres)
        {
            num_canch=delete_list_el(&ptrptr);
            // Ora ptrptr non e' piu' valido!!! Dovresti mettere chi lo punta a NULL, e mettere ptrptr a NULL
        }
        else
            ptrptr=(ptrptr)->next_ptr;
    }

    return num_canch;
}
__________________
In God we trust; all others bring data
sottovento è offline   Rispondi citando il messaggio o parte di esso
Old 23-01-2014, 11:07   #5
Daniels118
Senior Member
 
L'Avatar di Daniels118
 
Iscritto dal: Jan 2014
Messaggi: 852
@sottovento
Non è così: delete_list_el prende il puntatore a ptrptr e aggiorna ptrptr dopo aver cancellato l'elemento a cui punta.

@biondina
Sebbene la logica della cancellazione sia un po' contorta, non vedo alcun errore, il programma funziona correttamente con i dati di input che hai indicato.
Daniels118 è offline   Rispondi citando il messaggio o parte di esso
Old 23-01-2014, 11:16   #6
biondina
Junior Member
 
Iscritto dal: Jan 2014
Messaggi: 7
[quote=Daniels118;40614963]@sottovento

ma perche allora se come soglia inserisco un valore che non presente in lista inserita, il valore di ritono mi da un numero enorme tipo 22934 se deve ritornare ad esempio 3 ?
biondina è offline   Rispondi citando il messaggio o parte di esso
Old 23-01-2014, 11:22   #7
sottovento
Senior Member
 
L'Avatar di sottovento
 
Iscritto dal: Nov 2005
Città: Texas
Messaggi: 1722
Quote:
Originariamente inviato da Daniels118 Guarda i messaggi
@sottovento
Non è così: delete_list_el prende il puntatore a ptrptr e aggiorna ptrptr dopo aver cancellato l'elemento a cui punta.

Si, avevo visto male, il problema e' in num_canch:
Codice:
int camb_list (struct list*ptrptr,int thres) /*incrementa valori della lista per 1, fino a trovare uno >= di soglia. se trova un elemento > lo cancella dalla lista */
{
    int num_canch;
    while (ptrptr!=NULL && (ptrptr)->value<=thres)
    {
        (ptrptr)->value=(ptrptr)->value+1;
        if ((ptrptr)->value>=thres)
        {
            num_canch=delete_list_el(&ptrptr);
        }
        else
            ptrptr=(ptrptr)->next_ptr;
    }

    return num_canch;
}
In pratica, se tutti i valori che hai inserito sono maggiori della soglia, allora ottieni risultati a capocchia
__________________
In God we trust; all others bring data

Ultima modifica di sottovento : 23-01-2014 alle 11:28.
sottovento è offline   Rispondi citando il messaggio o parte di esso
Old 23-01-2014, 11:41   #8
Daniels118
Senior Member
 
L'Avatar di Daniels118
 
Iscritto dal: Jan 2014
Messaggi: 852
A me il programma funziona senza problemi:
Daniels118 è offline   Rispondi citando il messaggio o parte di esso
Old 23-01-2014, 11:41   #9
biondina
Junior Member
 
Iscritto dal: Jan 2014
Messaggi: 7
In pratica, se tutti i valori che hai inserito sono maggiori della soglia, allora ottieni risultati a capocchia[/quote]

ho provato a fare cosi:
int camb_list (struct list*ptrptr,int thres) {
int num_canch;
num_canch=0;
while (ptrptr!=NULL)
{ (ptrptr)->value=(ptrptr)->value+1;
if ((ptrptr)->value>=thres){
delete_list_el(&ptrptr);
num_canch++;
ptrptr=(ptrptr)->next_ptr;
}
else
ptrptr=(ptrptr)->next_ptr;
}
return num_canch;
}

void delete_list_el(struct list**ptrptr){
struct list*tmp;
tmp=*ptrptr;
*ptrptr=(*ptrptr)->next_ptr;
free(tmp);


Sembra meglio, ma cmq mi torna il valore un po sbagliato. ad esempio se deve restituire 4 mi restituische 2, se 10 torna 5 ecc.
cosa devo cambiare?
P.S. io non sono italiana quindi mi potresti spiegare in modo piu semplice
biondina è offline   Rispondi citando il messaggio o parte di esso
Old 23-01-2014, 11:42   #10
biondina
Junior Member
 
Iscritto dal: Jan 2014
Messaggi: 7
Quote:
Originariamente inviato da Daniels118 Guarda i messaggi
A me il programma funziona senza problemi:

MA COME MAI!!???

a me no funziona
biondina è offline   Rispondi citando il messaggio o parte di esso
Old 23-01-2014, 11:45   #11
Daniels118
Senior Member
 
L'Avatar di Daniels118
 
Iscritto dal: Jan 2014
Messaggi: 852
Ah, scusa, non avevo visto l'ultima nota.
Daniels118 è offline   Rispondi citando il messaggio o parte di esso
Old 23-01-2014, 11:45   #12
sottovento
Senior Member
 
L'Avatar di sottovento
 
Iscritto dal: Nov 2005
Città: Texas
Messaggi: 1722
Quote:
Originariamente inviato da Daniels118 Guarda i messaggi
A me il programma funziona senza problemi:
Prova ad inserire gli stessi numeri di prima, ma 1 come soglia
__________________
In God we trust; all others bring data
sottovento è offline   Rispondi citando il messaggio o parte di esso
Old 23-01-2014, 11:52   #13
sottovento
Senior Member
 
L'Avatar di sottovento
 
Iscritto dal: Nov 2005
Città: Texas
Messaggi: 1722
Quote:
Originariamente inviato da biondina Guarda i messaggi
MA COME MAI!!???

a me no funziona
L'esempio che hai pubblicato mi sembra corretto: prima incrementi e poi controlli che il valore sia >= della soglia. Quindi il 6 diventa 7 e rientra nell'insieme degli elementi da cancellare.
Hai un altro esempio?

EDIT - ops, sono sbadato:
Codice:
int camb_list (struct list*ptrptr,int thres)
{
    int num_canch;
    num_canch=0;
    while (ptrptr!=NULL)
    {
        (ptrptr)->value=(ptrptr)->value+1;
        if ((ptrptr)->value>=thres)
        {
            delete_list_el(&ptrptr);   // OK - Questa cancella l'elemento corrente, e l'elemento successivo diventa corrente
            num_canch++;  // OK - incrementi il tuo contatore
            ptrptr=(ptrptr)->next_ptr;  // NO! Salti l'elemento successivo che e' diventato corrente! Non mi piace per niente!!!!
        }
        else
            ptrptr=(ptrptr)->next_ptr;
    }
    return num_canch;
}
__________________
In God we trust; all others bring data

Ultima modifica di sottovento : 23-01-2014 alle 11:56.
sottovento è offline   Rispondi citando il messaggio o parte di esso
Old 23-01-2014, 12:00   #14
biondina
Junior Member
 
Iscritto dal: Jan 2014
Messaggi: 7
Quote:
Originariamente inviato da sottovento Guarda i messaggi
Hai un altro esempio?

Se faccio in questo modo:


int camb_list (struct list*ptrptr,int thres) {
int num_canch;
num_canch=0;
while (ptrptr!=NULL)
{ (ptrptr)->value=(ptrptr)->value+1;
if ((ptrptr)->value>=thres){
delete_list_el(&ptrptr);
num_canch++;
ptrptr=(ptrptr)->next_ptr;
}
else
ptrptr=(ptrptr)->next_ptr;
}
return num_canch;
}

void delete_list_el(struct list**ptrptr){
struct list*tmp;
tmp=*ptrptr;
*ptrptr=(*ptrptr)->next_ptr;
free(tmp);


mi fa:

lista inserita: 2 4 6 8 10 12
soglia 7
numero di el cancellati 2

invece deve essere 4
biondina è offline   Rispondi citando il messaggio o parte di esso
Old 23-01-2014, 12:01   #15
sottovento
Senior Member
 
L'Avatar di sottovento
 
Iscritto dal: Nov 2005
Città: Texas
Messaggi: 1722
Scusa, ho fatto un edit al post precedente, probabilmente mentre scrivevi. Non lo ricopio qui per ovvii motivi, prova a rileggerlo ora.
__________________
In God we trust; all others bring data
sottovento è offline   Rispondi citando il messaggio o parte di esso
Old 23-01-2014, 12:07   #16
biondina
Junior Member
 
Iscritto dal: Jan 2014
Messaggi: 7
Quote:
Originariamente inviato da sottovento Guarda i messaggi

EDIT - ops, sono sbadato:
Codice:
int camb_list (struct list*ptrptr,int thres)
{
    int num_canch;
    num_canch=0;
    while (ptrptr!=NULL)
    {
        (ptrptr)->value=(ptrptr)->value+1;
        if ((ptrptr)->value>=thres)
        {
            delete_list_el(&ptrptr);   // OK - Questa cancella l'elemento corrente, e l'elemento successivo diventa corrente
            num_canch++;  // OK - incrementi il tuo contatore
            ptrptr=(ptrptr)->next_ptr;  // NO! Salti l'elemento successivo che e' diventato corrente! Non mi piace per niente!!!!
        }
        else
            ptrptr=(ptrptr)->next_ptr;
    }
    return num_canch;
}

SIIII!!!! Ora funziona!!
Grazie mille!
biondina è offline   Rispondi citando il messaggio o parte di esso
Old 21-02-2014, 02:49   #17
mb1559
Junior Member
 
Iscritto dal: Feb 2014
Messaggi: 2
Quote:
Originariamente inviato da biondina Guarda i messaggi
SIIII!!!! Ora funziona!!
Grazie mille!
Potresti inviarmi il programma completo? Le modifiche suggerite non mi funzionano:confused. Dove sbaglio?
mb1559 è offline   Rispondi citando il messaggio o parte di esso
Old 22-02-2014, 11:33   #18
sottovento
Senior Member
 
L'Avatar di sottovento
 
Iscritto dal: Nov 2005
Città: Texas
Messaggi: 1722
Quote:
Originariamente inviato da mb1559 Guarda i messaggi
Potresti inviarmi il programma completo? Le modifiche suggerite non mi funzionano:confused. Dove sbaglio?
Scusa il ritardo
Allegati
File Type: zip test.zip (5.5 KB, 8 visite)
__________________
In God we trust; all others bring data
sottovento è offline   Rispondi citando il messaggio o parte di esso
Old 22-02-2014, 19:43   #19
mb1559
Junior Member
 
Iscritto dal: Feb 2014
Messaggi: 2
Quote:
Originariamente inviato da sottovento Guarda i messaggi
Scusa il ritardo
Ti ringrazio della risposta, ma nel file "test" non c'è il programma o le indicazioni per eliminare errore! Ti risulta sia così o devo prendere atto che il c non è cosa per me?

ciao grazie
mb1559 è offline   Rispondi citando il messaggio o parte di esso
 Rispondi


Recensione vivo X300 Pro: è ancora lui il re della fotografia mobile, peccato per la batteria Recensione vivo X300 Pro: è ancora lui il...
Lenovo Legion Go 2: Ryzen Z2 Extreme e OLED 8,8'' per spingere gli handheld gaming PC al massimo Lenovo Legion Go 2: Ryzen Z2 Extreme e OLED 8,8'...
AWS re:Invent 2025: inizia l'era dell'AI-as-a-Service con al centro gli agenti AWS re:Invent 2025: inizia l'era dell'AI-as-a-Se...
Cos'è la bolla dell'IA e perché se ne parla Cos'è la bolla dell'IA e perché se...
BOOX Palma 2 Pro in prova: l'e-reader diventa a colori, e davvero tascabile BOOX Palma 2 Pro in prova: l'e-reader diventa a ...
Xbox Cloud Gaming arriva su Amazon Fire ...
Un blackout a San Francisco manda in til...
Windows 11 è diventato più...
Apple cambia strategia a causa della cri...
007 First Light: uscita rimandata di due...
Samsung Galaxy A37 e A57: il comparto fo...
DAZN lancia la sua offerta di Natale: My...
Gigabyte fa marcia indietro? Sparito il ...
Alcuni rivenditori giapponesi bloccano l...
Le feste non placano Amazon, anzi: aggio...
Roborock Q10 S5+ a un super prezzo: robo...
Formula sceglie WINDTRE BUSINESS per gar...
EXPO 1.20: AMD migliora il supporto all'...
MacBook Pro con chip M4, 24GB di RAM e 1...
Lefant M330 da 6.000Pa a 139€ o ECOVACS ...
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: 00:05.


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