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 21-08-2008, 12:23   #1
Composition86
Senior Member
 
L'Avatar di Composition86
 
Iscritto dal: Jul 2005
Messaggi: 406
[C] Semplice esercizio con uso del while

Quote:
/*Determinazione dei Km fatti ad ogni pieno di benzina*/
#include <stdio.h>
#include <stdlib.h>

main()
{
int contatore, km, litri, kmallitro, kmallitrotot, media;

contatore = 0;

printf ("Inserire i kilometri percorsi con ogni pieno (-1 per uscire: \n");
scanf ("%d", &km);
printf ("Inserire i litri di benzina utilizzati: \n");
scanf ("%d", &litri);
kmallitro = km / litri;
printf ("Il numero di km al litro percorsi e': %d \n", kmallitro);

while (km != -1) {
printf ("Inserire i kilometri percorsi con ogni pieno (-1 per uscire: \n");
scanf ("%d", &km);
printf ("Inserire i litri di benzina utilizzati: \n");
scanf ("%d", &litri);
kmallitro = km / litri;
printf ("Il numero di km al litro percorsi e': %d \n", kmallitro);
kmallitrotot = kmallitrotot + kmallitro;
contatore = contatore + 1;
}

if (contatore != 0) {
media = kmallitrotot / contatore;
printf ("La media dei km con un pieno e': %d \n", media);
}
else
printf ("Non e' stato inserito nessun dato. \n");

system("pause");
return 0;
}
Sto facendo questo semplice esercizio, il cui obiettivo è calcolare i km/litro ed infinie trovare il valore medio di tutti i km/litro.

Ecco i miei dubbi:
-Prima del "while", se non rimetto tutta la parte in cui si richiede l'inserimento dei dati ed il calcolo, il programma non funziona correttamente, perchè?
-Se digito il valore sentinella "-1" (mediante il quale dovrei uscire dal programma), questo viene inserito come un comune dato e quindi non termina l'iterazione.
-La media finale non funziona.

Mi potreste fare un po' di chiarezza? Grazie.

Ultima modifica di Composition86 : 21-08-2008 alle 12:59.
Composition86 è offline   Rispondi citando il messaggio o parte di esso
Old 21-08-2008, 13:34   #2
k0nt3
Senior Member
 
Iscritto dal: Dec 2005
Messaggi: 7260
intanto metti il codice tra i tag CODE e /CODE perchè se lo metti nei tag QUOTE non si indenta
k0nt3 è offline   Rispondi citando il messaggio o parte di esso
Old 21-08-2008, 13:50   #3
k0nt3
Senior Member
 
Iscritto dal: Dec 2005
Messaggi: 7260
ecco qualche spiegazione:
- se non rimetti la parte dentro il while prima del while, il codice non funziona perchè le variabili non sono inizializzate. devi inizializzare tutte le variabili a 0, altrimenti il comportamento del programma non è predicibile

- questo perchè il controllo sul valore di km viene fatto all'inizio di ogni ciclo, quindi una volta che assegni il valore -1 alla variabile km il ciclo continua e si interrompe al ciclo successivo

- se inizializzi le variabili dovrebbe funzionare

ps. usa getchar() al posto di system("pause").
system("pause") non è standard e inoltre è brutto
k0nt3 è offline   Rispondi citando il messaggio o parte di esso
Old 21-08-2008, 13:52   #4
Composition86
Senior Member
 
L'Avatar di Composition86
 
Iscritto dal: Jul 2005
Messaggi: 406
Codice:
/*Determinazione dei Km fatti ad ogni pieno di benzina*/
#include <stdio.h>
#include <stdlib.h>

main()
{
   int contatore, km, litri, kmallitro, kmallitrotot, media;

   contatore = 0;
   
      printf ("Inserire i kilometri percorsi con ogni pieno (-1 per uscire: \n");
      scanf ("%d", &km);
      printf ("Inserire i litri di benzina utilizzati: \n");
      scanf ("%d", &litri);
      kmallitro = km / litri;
      printf ("Il numero di km al litro percorsi e': %d \n", kmallitro);

   while (km  != -1) {
      printf ("Inserire i kilometri percorsi con ogni pieno (-1 per uscire: \n");
      scanf ("%d", &km);
      printf ("Inserire i litri di benzina utilizzati: \n");
      scanf ("%d", &litri);
      kmallitro = km / litri;
      printf ("Il numero di km al litro percorsi e': %d \n", kmallitro);
      kmallitrotot = kmallitrotot + kmallitro;
      contatore = contatore + 1;
      }

   if (contatore != 0) {
      media = kmallitrotot / contatore;
      printf ("La media dei km con un pieno e': %d \n", media);
   }
   else
      printf ("Non e' stato inserito nessun dato. \n");

   system("pause");
   return 0;
}
Si vero, meglio così.
Composition86 è offline   Rispondi citando il messaggio o parte di esso
Old 21-08-2008, 13:56   #5
Composition86
Senior Member
 
L'Avatar di Composition86
 
Iscritto dal: Jul 2005
Messaggi: 406
Quote:
Originariamente inviato da k0nt3 Guarda i messaggi
ecco qualche spiegazione:
- se non rimetti la parte dentro il while prima del while, il codice non funziona perchè le variabili non sono inizializzate. devi inizializzare tutte le variabili a 0, altrimenti il comportamento del programma non è predicibile

- questo perchè il controllo sul valore di km viene fatto all'inizio di ogni ciclo, quindi una volta che assegni il valore -1 alla variabile km il ciclo continua e si interrompe al ciclo successivo

- se inizializzi le variabili dovrebbe funzionare

ps. usa getchar() al posto di system("pause").
system("pause") non è standard e inoltre è brutto
Intanto ti ringrazio, fra un po' provo e vedo cosa ne esce.
il system("pause") è un comando che sto usando temporaneamente per visualizzare il programma (praticamente appiccicato senza sapere cosa sia), appena arrivo a studiare la getchar() lo cambio!
Composition86 è offline   Rispondi citando il messaggio o parte di esso
Old 21-08-2008, 14:03   #6
k0nt3
Senior Member
 
Iscritto dal: Dec 2005
Messaggi: 7260
come non detto getchar() poi ha problemi quando usi la scanf... vai pure avanti con il tuo passo
k0nt3 è offline   Rispondi citando il messaggio o parte di esso
Old 21-08-2008, 15:20   #7
Composition86
Senior Member
 
L'Avatar di Composition86
 
Iscritto dal: Jul 2005
Messaggi: 406
Ho provato a fare un po' di cambiamenti, purtroppo non ho ottenuto nulla.

Il risultato è sempre che se inserisco il valore sentinella "-1" (a tutte e due le variabili, visto che ci sono, ho provato anche con l'OR nella condizione del "while") il programma esegue la divisione con tale numero (ovviamente non richiesta), ricomincia poi un altro ciclo e così via.
Composition86 è offline   Rispondi citando il messaggio o parte di esso
Old 21-08-2008, 16:12   #8
Composition86
Senior Member
 
L'Avatar di Composition86
 
Iscritto dal: Jul 2005
Messaggi: 406
Quote:
Originariamente inviato da k0nt3 Guarda i messaggi
ecco qualche spiegazione:
- questo perchè il controllo sul valore di km viene fatto all'inizio di ogni ciclo, quindi una volta che assegni il valore -1 alla variabile km il ciclo continua e si interrompe al ciclo successivo
Codice:
while (km  != -1) {
      printf ("Inserire i kilometri percorsi con ogni pieno (-1 per uscire: \n");
      scanf ("%d", &km);
      printf ("Inserire i litri di benzina utilizzati: \n");
      scanf ("%d", &litri);
      kmallitro = km / litri;
      printf ("Il numero di km al litro percorsi e': %d \n", kmallitro);
      kmallitrotot = kmallitrotot + kmallitro;
      contatore = contatore + 1;
      }
Credo di aver intuito cosa vuoi dire, ma mi sfugge un particolare: io inserisco "-1" a km che poi viene assegnato tramite scanf ad una certa locazione di memoria.
Il controllo su questa variabile viene effettivamente fatto quando il ciclo ricomincia.
Io invece vorrei che venisse fatto subito, al primo tentativo ed evitare (se possibile) di riscrivere tutta la parte iniziale ridondante (ho provato ad inizializzare tutte le variabili). Ti ringrazio per l'aiuto.

Ultima modifica di Composition86 : 21-08-2008 alle 16:22. Motivo: Precisazione
Composition86 è offline   Rispondi citando il messaggio o parte di esso
Old 21-08-2008, 16:36   #9
k0nt3
Senior Member
 
Iscritto dal: Dec 2005
Messaggi: 7260
ad esempio potresti fare una roba del genere:
Codice:
while (km != -1) {
        printf ("Inserire i kilometri percorsi con ogni pieno (-1 per uscire): \n");
        scanf ("%d", &km);
        if(km >= 0) {
            printf ("Inserire i litri di benzina utilizzati: \n");
            scanf ("%d", &litri);
            kmallitro = km / litri;
            printf ("Il numero di km al litro percorsi e': %d \n", kmallitro);
            kmallitrotot = kmallitrotot + kmallitro;
            contatore = contatore + 1;
        }
    }
che calcola i km al litro solo se la variabile km contiene un numero maggiore di 0.
in questo modo quando inserisci -1 la condizione nell'if non è verificata e il ciclo termina subito
k0nt3 è offline   Rispondi citando il messaggio o parte di esso
Old 21-08-2008, 16:49   #10
Composition86
Senior Member
 
L'Avatar di Composition86
 
Iscritto dal: Jul 2005
Messaggi: 406
Quote:
Originariamente inviato da k0nt3 Guarda i messaggi
ad esempio potresti fare una roba del genere:
Codice:
while (km != -1) {
        printf ("Inserire i kilometri percorsi con ogni pieno (-1 per uscire): \n");
        scanf ("%d", &km);
        if(km >= 0) {
            printf ("Inserire i litri di benzina utilizzati: \n");
            scanf ("%d", &litri);
            kmallitro = km / litri;
            printf ("Il numero di km al litro percorsi e': %d \n", kmallitro);
            kmallitrotot = kmallitrotot + kmallitro;
            contatore = contatore + 1;
        }
    }
che calcola i km al litro solo se la variabile km contiene un numero maggiore di 0.
in questo modo quando inserisci -1 la condizione nell'if non è verificata e il ciclo termina subito
Si l'effetto è lo stesso, ma a questo punto la condizione del while è una inutile aggiunta.
E poi, attenendomi all'esercizio del libro, volevo avere un unico valore per cui terminare il ciclo: adesso la condizione dell' "if" per i numeri positivi funziona, ma se invece mi trovo a dover fare un programma dove le variabili possono assumere anche valori negativi, tale condizione non sarebbe più funzionale.
Composition86 è offline   Rispondi citando il messaggio o parte di esso
Old 21-08-2008, 16:59   #11
k0nt3
Senior Member
 
Iscritto dal: Dec 2005
Messaggi: 7260
beh non è proprio inutile la condizione del while..
per come l'ho scritto io funziona così:
- se il numero è >= 0 calcola i km al litro
- se il numero è negativo non calcola niente ma va avanti a chiedere numeri
- se il numero è -1 termina il ciclo

se vuoi trovare una soluzione più elegante mi sa che devi cambiare il modo con cui dici al programma di terminare il ciclo. ma dipende da quello che devi fare
k0nt3 è offline   Rispondi citando il messaggio o parte di esso
Old 21-08-2008, 17:19   #12
Composition86
Senior Member
 
L'Avatar di Composition86
 
Iscritto dal: Jul 2005
Messaggi: 406
Ti ringrazio ancora.
Mi devo solo attenere all'esercizio, per il momento mi interessa solo capire quello che faccio, non avere una soluzione elegante. Quindi va bene come hai fatto tu. Penso di poterl archiviare l'esercizio.
Composition86 è 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: 05:58.


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