Torna indietro   Hardware Upgrade Forum > Software > Programmazione

Recensione HUAWEI Mate X7: un foldable ottimo, ma restano i soliti problemi
Recensione HUAWEI Mate X7: un foldable ottimo, ma restano i soliti problemi
Mate X7 rinnova la sfida nel segmento dei pieghevoli premium puntando su un design ancora più sottile e resistente, unito al ritorno dei processori proprietari della serie Kirin. L'assenza dei servizi Google e del 5G pesa ancora sull'esperienza utente, ma il comparto fotografico e la qualità costruttiva cercano di compensare queste mancanze strutturali con soluzioni ingegneristiche di altissimo livello
Nioh 3: souls-like punitivo e Action RPG
Nioh 3: souls-like punitivo e Action RPG
Nioh 3 aggiorna la formula Team NINJA con aree esplorabili più grandi, due stili di combattimento intercambiabili al volo (Samurai e Ninja) e un sistema di progressione pieno di attività, basi nemiche e sfide legate al Crogiolo. La recensione entra nel dettaglio su combattimento, build, progressione e requisiti PC
Test in super anteprima di Navimow i220 LiDAR: il robot tagliaerba per tutti
Test in super anteprima di Navimow i220 LiDAR: il robot tagliaerba per tutti
La facilità di installazione e la completa automazione di tutte le fasi di utilizzo, rendono questo prodotto l'ideale per molti clienti. Ecco com'è andata la nostra prova in anteprima
Tutti gli articoli Tutte le news

Vai al Forum
Rispondi
 
Strumenti
Old 14-11-2006, 11: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, 12: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, 12: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, 11: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, 11: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, 12: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, 12: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, 18: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


Recensione HUAWEI Mate X7: un foldable ottimo, ma restano i soliti problemi Recensione HUAWEI Mate X7: un foldable ottimo, m...
Nioh 3: souls-like punitivo e Action RPG Nioh 3: souls-like punitivo e Action RPG
Test in super anteprima di Navimow i220 LiDAR: il robot tagliaerba per tutti Test in super anteprima di Navimow i220 LiDAR: i...
Dark Perk Ergo e Sym provati tra wireless, software via browser e peso ridotto Dark Perk Ergo e Sym provati tra wireless, softw...
DJI RS 5: stabilizzazione e tracking intelligente per ogni videomaker DJI RS 5: stabilizzazione e tracking intelligent...
Dalle auto ai robot umanoidi: Faraday Fu...
Vodafone annuncia la dismissione di un s...
Stiga lancia i nuovi robot tagliaerba co...
Bullismo e cyberbullismo, Keenetic lanci...
Con AI Skills Checker Bitdefender mette ...
E-bike giapponese con 1.000 km di autono...
Un eVTOL con cui basta saper andare in b...
Dal mercato cinese al mondo: HONOR firma...
Sovranità digitale: l'UE sperimen...
Accesso alla memoria su Windows 11 solo ...
iPhone 18 Pro Max con batteria da oltre ...
Windows 11, cali di prestazioni sulle GP...
Un altro iPhone economico è in arrivo a ...
The Grand Tour 2026: ecco chi saranno i ...
Dai display alle soluzioni: Samsung tra ...
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: 17:41.


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