Torna indietro   Hardware Upgrade Forum > Software > Programmazione

iPhone 17 Pro: più di uno smartphone. È uno studio di produzione in formato tascabile
iPhone 17 Pro: più di uno smartphone. È uno studio di produzione in formato tascabile
C'è tanta sostanza nel nuovo smartphone della Mela dedicato ai creator digitali. Nuovo telaio in alluminio, sistema di raffreddamento vapor chamber e tre fotocamere da 48 megapixel: non è un semplice smartphone, ma uno studio di produzione digitale on-the-go
Intel Panther Lake: i processori per i notebook del 2026
Intel Panther Lake: i processori per i notebook del 2026
Panther Lake è il nome in codice della prossima generazione di processori Intel Core Ultra, che vedremo al debutto da inizio 2026 nei notebook e nei sistemi desktop più compatti. Nuovi core, nuove GPU e soprattutto una struttura a tile che vede per la prima volta l'utilizzo della tecnologia produttiva Intel 18A: tanta potenza in più, ma senza perdere in efficienza
Intel Xeon 6+: è tempo di Clearwater Forest
Intel Xeon 6+: è tempo di Clearwater Forest
Intel ha annunciato la prossima generazione di processori Xeon dotati di E-Core, quelli per la massima efficienza energetica e densità di elaborazione. Grazie al processo produttivo Intel 18A, i core passano a un massimo di 288 per ogni socket, con aumento della potenza di calcolo e dell'efficienza complessiva.
Tutti gli articoli Tutte le news

Vai al Forum
Rispondi
 
Strumenti
Old 14-11-2006, 10:58   #1
nongio
Senior Member
 
L'Avatar di nongio
 
Iscritto dal: May 2004
Città: Pianeta Terra
Messaggi: 1593
[C] help esercizio banale

ciao a tuttiz, devo fare un esercizio per l'universita, ma non mi viene..... e' banale ma nn vuole venirmi...

Scrivere un programma che:

1) Legge quanti elementi ha un' array (al massimo 30),
2) legge gli elementi dell'array.

3) Fa un ciclo in cui
a) legge un numero (che chiamero' n nel seguito)
b) mette gli elementi minori di n in un'array e quelli
maggiori di n in un'altra array,
c) stampa
"Ci sono i seguenti elementi minori di n nell'array"
seguito dall'elenco degli elementi minori di n
"Ci sono i seguenti elementi maggiori di n nell'array"
seguito dall'elenco degli elementi maggiori di n

Potete decidere voi come far interrompere il ciclo.

senza usale le funzioni come lo fareste... grazie
__________________
|Antec Nine Hundred by me~LC Titan 560W~Asus P5QD Turbo~Intel Q9550~Corsair Dominator xms2-8500~Sapphire HD5870~SB Audigy X-Fi XtremeGamer~Samsung 320Gb sataII~LG dvd-rw~2xAcer P193w + Samsung SM 2243SN~Logitech z-5300~|Notebook MSI S271| Fastweb 20Mb ~ BOINC GOD - 15 UOTD
nongio è offline   Rispondi citando il messaggio o parte di esso
Old 14-11-2006, 11:17   #2
andbin
Senior Member
 
L'Avatar di andbin
 
Iscritto dal: Nov 2005
Città: TO
Messaggi: 5206
Quote:
Originariamente inviato da nongio
Scrivere un programma che:

1) Legge quanti elementi ha un' array (al massimo 30),
2) legge gli elementi dell'array.
Innanzitutto che tipo di array??? Come devono essere assegnati i valori nell'array?? Dall'utente tramite tastiera? Direttamente nel sorgente??

Spiega meglio se vuoi un aiuto.
__________________
Andrea, SCJP 5 (91%) - SCWCD 5 (94%)
andbin è offline   Rispondi citando il messaggio o parte di esso
Old 14-11-2006, 11:49   #3
MEMon
Senior Member
 
Iscritto dal: Dec 2002
Messaggi: 3359
Si ma se fai l'uni e non ti viene un esercizio del genere ti conviene metterti sotto veramente prima dell'esame...
MEMon è offline   Rispondi citando il messaggio o parte di esso
Old 16-11-2006, 10:10   #4
nongio
Senior Member
 
L'Avatar di nongio
 
Iscritto dal: May 2004
Città: Pianeta Terra
Messaggi: 1593
Quote:
Originariamente inviato da andbin
Innanzitutto che tipo di array??? Come devono essere assegnati i valori nell'array?? Dall'utente tramite tastiera? Direttamente nel sorgente??

Spiega meglio se vuoi un aiuto.
Ciao scusa se rispondo cosi' in ritardo...

cmq si il valore da inserire e' da tastiera dall'utente...

Fino ad ora ho proseguito cosi':

#include <stdio.h>
#include <math.h>
#define imax 30


main ()
{

int arr[imax], num,i;
do
{
printf("Inserire il numero dei valori da inserire : ");
scanf ("%d", &num);
}
while((num<1) || (num>30));
for (i=0; i<num; i++)
{
printf("Inserire i valori dell'array:");
scanf("%d",&arr[i]);
}
if ( num>imax)
printf("I valori superano la dimensione massima dell'array ovvero 30 elementi " );
__________________
|Antec Nine Hundred by me~LC Titan 560W~Asus P5QD Turbo~Intel Q9550~Corsair Dominator xms2-8500~Sapphire HD5870~SB Audigy X-Fi XtremeGamer~Samsung 320Gb sataII~LG dvd-rw~2xAcer P193w + Samsung SM 2243SN~Logitech z-5300~|Notebook MSI S271| Fastweb 20Mb ~ BOINC GOD - 15 UOTD
nongio è offline   Rispondi citando il messaggio o parte di esso
Old 16-11-2006, 10:34   #5
andbin
Senior Member
 
L'Avatar di andbin
 
Iscritto dal: Nov 2005
Città: TO
Messaggi: 5206
Quote:
Originariamente inviato da nongio
#include <stdio.h>
#include <math.h>
#define imax 30


main ()
{

int arr[imax], num,i;
do
{
printf("Inserire il numero dei valori da inserire : ");
scanf ("%d", &num);
}
while((num<1) || (num>30));
for (i=0; i<num; i++)
{
printf("Inserire i valori dell'array:");
scanf("%d",&arr[i]);
}
if ( num>imax)
printf("I valori superano la dimensione massima dell'array ovvero 30 elementi " );
Fin qui mi sembra ok. Solo alcune cosette: main() deve ritornare un int. Inoltre <math.h> non credo che ti serva.

Non ho solo capito perché alla fine fai il test di num>max. num non vale mai più di 30, perché fai già il controllo nel do-while dell'input.

A questo punto, se ho capito bene, dovresti:
- Richiedere in input un numero.
- Mettere i valori minori del numero in un array e mettere i valori maggiori del numero in un altro array.

Tutto questo in un ciclo per poter ripetere la suddivisione più volte, eventualmente.

Innanzitutto dovresti dichiarare altri 2 array di lunghezza imax. Dovrai anche avere 2 variabili che tengono la lunghezza dei 2 array.
Poi fai un ciclo for per scansionare l'array principale, per ogni elemento fai il test con il numero inserito e in base al minore/maggiore, lo aggiungi ad uno dei due array (incrementando la variabile della lunghezza).

Prova un po', poi se hai problemi, chiedi pure.
__________________
Andrea, SCJP 5 (91%) - SCWCD 5 (94%)
andbin è offline   Rispondi citando il messaggio o parte di esso
Old 16-11-2006, 11:22   #6
nongio
Senior Member
 
L'Avatar di nongio
 
Iscritto dal: May 2004
Città: Pianeta Terra
Messaggi: 1593
ciao andbin, grazie della risposta.. sto provando a fare come hai detto tu ma ho qualche problemino tu hai scritto
-Poi fai un ciclo for per scansionare l'array principale, per ogni elemento fai il test con il numero inserito e in base al minore/maggiore, lo aggiungi ad uno dei due array (incrementando la variabile della lunghezza).

dopo aver dichiarato le variabilie altri 2 array di lunghezza imax gli faccio fare

printf("Inserire un valore: ");
scanf("%d", &n);
for (arr[i]=0; arr[i]<n; n++ )
{
armin[h]=arr[i];
printf("i valori sono: %d",armin[h]);
}

so che c'e' qualcosa che non va... perdonatemi davvero ma se nn me lo spiega qualcuno non ci arrivo

abbiate pazienza
__________________
|Antec Nine Hundred by me~LC Titan 560W~Asus P5QD Turbo~Intel Q9550~Corsair Dominator xms2-8500~Sapphire HD5870~SB Audigy X-Fi XtremeGamer~Samsung 320Gb sataII~LG dvd-rw~2xAcer P193w + Samsung SM 2243SN~Logitech z-5300~|Notebook MSI S271| Fastweb 20Mb ~ BOINC GOD - 15 UOTD
nongio è offline   Rispondi citando il messaggio o parte di esso
Old 16-11-2006, 11:41   #7
andbin
Senior Member
 
L'Avatar di andbin
 
Iscritto dal: Nov 2005
Città: TO
Messaggi: 5206
Quote:
Originariamente inviato da nongio
ciao andbin, grazie della risposta.. sto provando a fare come hai detto tu ma ho qualche problemino
Ti conviene dichiarare le variabili per i 3 array in questo modo:
Codice:
int arr[imax], arr_min[imax], arr_mag[imax];
int num, num_min, num_mag;
Una volta che hai tutti i valori (numero di elementi, gli N elementi e il numero per la suddivisione), fai un semplice ciclo for:
Codice:
for (i = 0; i < num; i++)
{
    ....
}
Dentro il ciclo dovrai testare se arr[i] è minore di 'n' oppure maggiore di 'n'. In base al test, dovrai inserire arr[i] in uno dei 2 array.
Nota che le variabili num_min e num_mag possono essere utilizzate sia per gli indici che per tenere la lunghezza dell'array.

Per essere più chiari: se nell'array arr_min hai già 2 elementi, allora num_min vale 2. Il prossimo elemento lo devi aggiungere proprio all'indice 2 (la terza cella) e poi devi incrementare il contatore.
__________________
Andrea, SCJP 5 (91%) - SCWCD 5 (94%)
andbin è offline   Rispondi citando il messaggio o parte di esso
Old 16-11-2006, 17:49   #8
nongio
Senior Member
 
L'Avatar di nongio
 
Iscritto dal: May 2004
Città: Pianeta Terra
Messaggi: 1593
Quote:
Originariamente inviato da andbin
Ti conviene dichiarare le variabili per i 3 array in questo modo:
Codice:
int arr[imax], arr_min[imax], arr_mag[imax];
int num, num_min, num_mag;
Una volta che hai tutti i valori (numero di elementi, gli N elementi e il numero per la suddivisione), fai un semplice ciclo for:
Codice:
for (i = 0; i < num; i++)
{
    ....
}
Dentro il ciclo dovrai testare se arr[i] è minore di 'n' oppure maggiore di 'n'. In base al test, dovrai inserire arr[i] in uno dei 2 array.
Nota che le variabili num_min e num_mag possono essere utilizzate sia per gli indici che per tenere la lunghezza dell'array.

Per essere più chiari: se nell'array arr_min hai già 2 elementi, allora num_min vale 2. Il prossimo elemento lo devi aggiungere proprio all'indice 2 (la terza cella) e poi devi incrementare il contatore.
grazie mille... provo e ti faccio sapere
__________________
|Antec Nine Hundred by me~LC Titan 560W~Asus P5QD Turbo~Intel Q9550~Corsair Dominator xms2-8500~Sapphire HD5870~SB Audigy X-Fi XtremeGamer~Samsung 320Gb sataII~LG dvd-rw~2xAcer P193w + Samsung SM 2243SN~Logitech z-5300~|Notebook MSI S271| Fastweb 20Mb ~ BOINC GOD - 15 UOTD
nongio è offline   Rispondi citando il messaggio o parte di esso
 Rispondi


iPhone 17 Pro: più di uno smartphone. È uno studio di produzione in formato tascabile iPhone 17 Pro: più di uno smartphone. &Eg...
Intel Panther Lake: i processori per i notebook del 2026 Intel Panther Lake: i processori per i notebook ...
Intel Xeon 6+: è tempo di Clearwater Forest Intel Xeon 6+: è tempo di Clearwater Fore...
4K a 160Hz o Full HD a 320Hz? Titan Army P2712V, a un prezzo molto basso 4K a 160Hz o Full HD a 320Hz? Titan Army P2712V,...
Recensione Google Pixel Watch 4: basta sollevarlo e si ha Gemini sempre al polso Recensione Google Pixel Watch 4: basta sollevarl...
Intel Core 13000 e 14000 aumentano uffic...
Gemini sta per arrivare in Google Maps: ...
2 minuti per vedere le 27 offerte imperd...
Ray-Ban Meta Display: tecnologia sorpren...
Un mini PC a prezzo stracciato, non cerc...
Al via i coupon nascosti di ottobre: qua...
Ferrari Elettrica si aggiorna solo in of...
Doppio sconto sugli smartphone top Xiaom...
Samsung è sempre più prota...
ChatGPT ha pregiudizi politici? Ecco cos...
Un solo iPhone rubato ha portato alla sc...
Xiaomi 17 Ultra sta arrivando: ecco come...
Il Motorola Edge 70 non ha più se...
Alcuni Galaxy S26 utilizzeranno il chip ...
Amazon, ecco i super sconti del weekend:...
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: 11:08.


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