Torna indietro   Hardware Upgrade Forum > Software > Programmazione

Prova GeForce NOW upgrade Blackwell: il cloud gaming cambia per sempre
Prova GeForce NOW upgrade Blackwell: il cloud gaming cambia per sempre
L'abbonamento Ultimate di GeForce NOW ora comprende la nuova architettura Blackwell RTX con GPU RTX 5080 che garantisce prestazioni tre volte superiori alla precedente generazione. Non si tratta solo di velocità, ma di un'esperienza di gioco migliorata con nuove tecnologie di streaming e un catalogo giochi raddoppiato grazie alla funzione Install-to-Play
Ecovacs Deebot X11 Omnicyclone: niente più sacchetto per lo sporco
Ecovacs Deebot X11 Omnicyclone: niente più sacchetto per lo sporco
Deebot X11 Omnicyclone implementa tutte le ultime tecnologie Ecovacs per l'aspirazione dei pavimenti di casa e il loro lavaggio, con una novità: nella base di ricarica non c'è più il sacchetto di raccolta dello sporco, sostituito da un aspirapolvere ciclonico che accumula tutto in un contenitore rigido
Narwal Flow: con il mocio orizzontale lava i pavimenti al meglio
Narwal Flow: con il mocio orizzontale lava i pavimenti al meglio
Grazie ad un mocio rotante che viene costantemente bagnato e pulito, Narwal Flow assicura un completo e capillare lavaggio dei pavimenti di casa. La logica di intellignza artificiale integrata guida nella pulizia tra i diversi locali, sfruttando un motore di aspirazione molto potente e un sistema basculante per la spazzola molto efficace sui tappeti di casa
Tutti gli articoli Tutte le news

Vai al Forum
Rispondi
 
Strumenti
Old 21-09-2011, 17:01   #1
Master94ga
Member
 
L'Avatar di Master94ga
 
Iscritto dal: Sep 2009
Messaggi: 133
[C]Problema record e tabelle

Il programma è questo:
Codice:
/*Scrivere un programmam che consenta di caricare un elenco di massimo 30 libri, ciascuno caratterizzato dai campi:
           -Titolo
           -Autore
           -Prezzo
Scrivere una funziona che trovi il libro di prezzo maggiore*/

#include <stdio.h>
#include <conio.h>

typedef struct tlibri
{
        char titolo [20];
        char autore [30];
        float prezzo [10];
};

tlibri libroprezmax;
tlibri elencolibri [100];

void prezzomax (tlibri libroprezmax, int n);

main ()
{
     int n,i;
     printf("Inserisci il numero dei libri: ");
     scanf("%d", &n);
     
     for(i=0;i<n;i++)
     {
                     printf("Inserisci il titolo del libro: ");
                     scanf("%s", elencolibri [i].titolo);
                     printf("Inserisci l'autore del libro: ");
                     scanf("%s", elencolibri [i].autore);
                     printf("Inserisci il prezzo del libro: ");
                     scanf("%f", elencolibri [i].prezzo);
                     prezzomax(libroprezmax,n);
     }
     getch();
}

void prezzomax (tlibri libroprezmax, int n)
{
Io non so come fare la funzione che trovi e stampi il libro con prezzo maggiore, consigli?
Master94ga è offline   Rispondi citando il messaggio o parte di esso
Old 21-09-2011, 17:26   #2
simo8
Member
 
Iscritto dal: Jul 2009
Messaggi: 146
la prima volta considera come prezzo massimo il primo libro e lo salvi in una variabile dopodichè controlli il prezzo sucessivo con quello che avevi salvato precendentemente , se è maggiore cambi il libro dal prezzo massimo altrimenti non fai niente .
simo8 è offline   Rispondi citando il messaggio o parte di esso
Old 21-09-2011, 17:52   #3
Master94ga
Member
 
L'Avatar di Master94ga
 
Iscritto dal: Sep 2009
Messaggi: 133
Ho risolto, ho cambiato tante cose:
Codice:
/*Scrivere un programmam che consenta di caricare un elenco di massimo 30 libri, ciascuno caratterizzato dai campi:
           -Titolo
           -Autore
           -Prezzo
Scrivere una funziona che trovi il libro di prezzo maggiore*/

#include <stdio.h>
#include <conio.h>

typedef struct tlibri
{
        char titolo[20];
        char autore[30];
        float prezzo;
};



int prezzomax( tlibri elencolibri[] , int n );

main ()
{
     int n,i,imax;
     tlibri elencolibri[30];
     printf("Inserisci il numero dei libri: ");
     scanf("%d", &n);
     
     for(i=0;i<n;i++)
     {
                     printf("Inserisci il titolo del libro: ");
                     scanf("%s", &elencolibri[i].titolo);
                     printf("Inserisci l'autore del libro: ");
                     scanf("%s", &elencolibri[i].autore);
                     printf("Inserisci il prezzo del libro: ");
                     scanf("%f", &elencolibri[i].prezzo);
     }
     imax= prezzomax( elencolibri, n );
     printf("Il libro con prezzo piu' alto e' :%s", elencolibri[imax].titolo);
     getch();
}

int prezzomax( tlibri elencolibri[] , int n )
{
     int I,imax;
     float ap;
     ap=elencolibri[0].prezzo;
     for(I=1;I<n;I++)
     {
      if(elencolibri[i].prezzo>ap)
      imax=I;

      return imax;
      }                                          
}
Master94ga è offline   Rispondi citando il messaggio o parte di esso
Old 21-09-2011, 19:44   #4
simo8
Member
 
Iscritto dal: Jul 2009
Messaggi: 146
l'unica cosa è che non fai nessun controllo per assicurarti che il numero n di libri sia effettivamente minore di 30 .
simo8 è offline   Rispondi citando il messaggio o parte di esso
Old 21-09-2011, 20:11   #5
Floris
Senior Member
 
L'Avatar di Floris
 
Iscritto dal: Jan 2007
Messaggi: 2267
Sicuro che la funzione prezzomax sia corretta?
Io la porrei così:
Codice:
int prezzomax( tlibri elencolibri[] , int n )
{
     int I,imax;
     float ap;
     ap=elencolibri[0].prezzo;
     imax = 0;
     for(I=1;I<n;I++)
     {
          if(elencolibri[I].prezzo>ap)
          {
          ap = elencolibri[I].prezzo;
          imax=I;
          }
     } 
     return imax;                                         
}
Poi potresti renderla più snella:
Codice:
int prezzomax( tlibri elencolibri[] , int n )
{
     int imax = 0;
     for(int i=1;i<n;i++)
     {
          if(elencolibri[i].prezzo>elencolibri[imax].prezzo)
              imax=i;
     }
     return imax;                                   
}
Poichè basta che ti ricordi l'indice e non anche il valore massimo.
__________________
Concluso con:...

Ultima modifica di Floris : 21-09-2011 alle 20:18.
Floris è offline   Rispondi citando il messaggio o parte di esso
 Rispondi


Prova GeForce NOW upgrade Blackwell: il cloud gaming cambia per sempre Prova GeForce NOW upgrade Blackwell: il cloud ga...
Ecovacs Deebot X11 Omnicyclone: niente più sacchetto per lo sporco Ecovacs Deebot X11 Omnicyclone: niente più...
Narwal Flow: con il mocio orizzontale lava i pavimenti al meglio Narwal Flow: con il mocio orizzontale lava i pav...
Panasonic 55Z95BEG cala gli assi: pannello Tandem e audio senza compromessi Panasonic 55Z95BEG cala gli assi: pannello Tande...
HONOR Magic V5: il pieghevole ultra sottile e completo! La recensione HONOR Magic V5: il pieghevole ultra sottile e co...
Battlefield 6: modalità Battle Royale gi...
Microsoft cambia rotta sul lavoro ibrido...
Una power station portatile da 1075Wh e ...
PayPal porta in Italia i pagamenti a rat...
ESA Solar Orbiter ha studiato il flusso ...
Larry Ellison guadagna 101 miliardi in u...
Johnson Controls amplia la gamma di solu...
NASA Perseverance: il rover potrebbe ave...
Quelli di Immuni si 'pappano' Vimeo: Ben...
Changan lancia la Deepal S05 in Europa, ...
Substrati in vetro, Intel smentisce le v...
ECOVACS DEEBOT T50 PRO OMNI Gen2 fa piaz...
Windelo 62: catamarano a vela che unisce...
Francia, in arrivo un incentivo di 1.000...
Haier, la sorpresa a IFA: la lavatrice C...
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:04.


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