Torna indietro   Hardware Upgrade Forum > Software > Programmazione

Le novità MSI del 2026 per i videogiocatori
Le novità MSI del 2026 per i videogiocatori
Con le nuove soluzioni della serie MEG, acronimo di MSI Enthusiast Gaming, l'azienda taiwanese vuole proporre per il 2026 una gamma di proposte desktop che si rivolgono direttamente all'utente più appassionato con schede madri, chassis e sistemi di raffreddamento. Non da ultimi troviamo anche gli alimentatori, che abbinano potenza a ricerca della massima sicurezza di funzionamento.
I nuovi schermi QD-OLED di quinta generazione di MSI, per i gamers
I nuovi schermi QD-OLED di quinta generazione di MSI, per i gamers
MSI continua ad investire nel proporre schermi pensati per rispondere alle esigenze dei videogiocatori, utilizzando la quinta generazione di tecnologia QD-OLED sviluppata da Samsung. Il modello MPG 341CQR QD-OLED X36 è lpultima novità al debutto in concomitanza con il CES 2026, uno schermo curvo di ampia risoluzione pensato per i videogiocatori più esigenti
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
Tutti gli articoli Tutte le news

Vai al Forum
Rispondi
 
Strumenti
Old 02-02-2014, 18:09   #1
uscrocc
Member
 
Iscritto dal: Feb 2014
Messaggi: 60
Array C++ semplici per voi, difficili per me

Il professore mi ha assegnato dei compiti per esercitarmi a fare gli array, ecco degli esercizi:

Spoiler:

Dopo aver acquisito da tastiera un intero n (n<= 30):
1. acquisire da tastiera n interi in un vettore ‘numeri1’;
2. visualizzarli in ordine inverso;
3. sommare gli elementi del vettore, e visualizzare il risultato;
4. visualizzare la media degli elementi, e visualizzare il risultato;


Il numero1 l'ho fatto ed è questo:
Spoiler:


//Dopo aver acquisito da tastiera un intero n (n<= 30):
//1. acquisire da tastiera n interi in un vettore ‘numeri1’;

#include <iostream>
using namespace std;
void numeri1(int vet[], int n );
int main()
{
int v1[100], m;
cout<<"Inserisci un elemento minore di 30"<<endl;
cin>>m;
if (m>30) {
return 0;
}
numeri1(v1,m);
return 0;
}

void numeri1(int vet[], int n)
{
for (int i=0; i<n; i++)
{
cout<<"Inserire elemento del vettore"<<endl;
cin>>vet[i];
}

}


Non vi sto chiedendo di farmi per forza l'esercizio! ma di spiegarmelo perchè a breve avrò il compito
uscrocc è offline   Rispondi citando il messaggio o parte di esso
Old 02-02-2014, 18:11   #2
uscrocc
Member
 
Iscritto dal: Feb 2014
Messaggi: 60
Il professore mi ha assegnato dei compiti per esercitarmi a fare gli array, ecco degli esercizi:


Dopo aver acquisito da tastiera un intero n (n<= 30):
1. acquisire da tastiera n interi in un vettore ‘numeri1’;
2. visualizzarli in ordine inverso;
3. sommare gli elementi del vettore, e visualizzare il risultato;
4. visualizzare la media degli elementi, e visualizzare il risultato;

Il numero1 l'ho fatto ed è questo:

//Dopo aver acquisito da tastiera un intero n (n<= 30):
//1. acquisire da tastiera n interi in un vettore ‘numeri1’;

#include <iostream>
using namespace std;
void numeri1(int vet[], int n );
int main()
{
int v1[100], m;
cout<<"Inserisci un elemento minore di 30"<<endl;
cin>>m;
if (m>30) {
return 0;
}
numeri1(v1,m);
return 0;
}

void numeri1(int vet[], int n)
{
for (int i=0; i<n; i++)
{
cout<<"Inserire elemento del vettore"<<endl;
cin>>vet[i];
}

}


Non vi sto chiedendo di farmi per forza l'esercizio! ma di spiegarmelo perchè a breve avrò il compito
uscrocc è offline   Rispondi citando il messaggio o parte di esso
Old 02-02-2014, 18:56   #3
vendettaaaaa
Senior Member
 
L'Avatar di vendettaaaaa
 
Iscritto dal: Jan 2012
Messaggi: 1267
Quote:
Originariamente inviato da uscrocc Guarda i messaggi
Il professore mi ha assegnato dei compiti per esercitarmi a fare gli array, ecco degli esercizi:


Dopo aver acquisito da tastiera un intero n (n<= 30):
1. acquisire da tastiera n interi in un vettore ‘numeri1’;
2. visualizzarli in ordine inverso;
3. sommare gli elementi del vettore, e visualizzare il risultato;
4. visualizzare la media degli elementi, e visualizzare il risultato;

Il numero1 l'ho fatto ed è questo:

//Dopo aver acquisito da tastiera un intero n (n<= 30):
//1. acquisire da tastiera n interi in un vettore ‘numeri1’;

#include <iostream>
using namespace std;
void numeri1(int vet[], int n );
int main()
{
int v1[100], m;
cout<<"Inserisci un elemento minore di 30"<<endl;
cin>>m;
if (m>30) {
return 0;
}
numeri1(v1,m);
return 0;
}

void numeri1(int vet[], int n)
{
for (int i=0; i<n; i++)
{
cout<<"Inserire elemento del vettore"<<endl;
cin>>vet[i];
}

}


Non vi sto chiedendo di farmi per forza l'esercizio! ma di spiegarmelo perchè a breve avrò il compito
Beh, quello che hai fatto finora presuppone la comprensione di certi concetti che sono gli stessi che necessiti per gli altri punti: iterare in un ciclo, come accedere agli elementi di un vettore.
Nel punto 2 basta iterare al contrario. Nel punto 3 basta accumulare i valori da qualche parte, nel punto 4 idem e in più devi fare una divisione...!
Ad ogni modo, dato che controlli che n sia minore o uguale a 30, non ha senso dimensionare un vettore con 100 elementi.
vendettaaaaa è offline   Rispondi citando il messaggio o parte di esso
Old 02-02-2014, 20:50   #4
uscrocc
Member
 
Iscritto dal: Feb 2014
Messaggi: 60
Quote:
Originariamente inviato da vendettaaaaa Guarda i messaggi
Beh, quello che hai fatto finora presuppone la comprensione di certi concetti che sono gli stessi che necessiti per gli altri punti: iterare in un ciclo, come accedere agli elementi di un vettore.
Nel punto 2 basta iterare al contrario. Nel punto 3 basta accumulare i valori da qualche parte, nel punto 4 idem e in più devi fare una divisione...!
Ad ogni modo, dato che controlli che n sia minore o uguale a 30, non ha senso dimensionare un vettore con 100 elementi.
Mi potresti scrivere il punto 4? La somma tra vettori non la ho chiara. E anche il punto 2. Grazie mille o
uscrocc è offline   Rispondi citando il messaggio o parte di esso
Old 02-02-2014, 22:04   #5
vendettaaaaa
Senior Member
 
L'Avatar di vendettaaaaa
 
Iscritto dal: Jan 2012
Messaggi: 1267
Quote:
Originariamente inviato da uscrocc Guarda i messaggi
Mi potresti scrivere il punto 4? La somma tra vettori non la ho chiara. E anche il punto 2. Grazie mille o
Scusa ma il punto 1 l'hai fatto tu per davvero...?
Il punto 4 sarebbe così: dopo aver letto i valori da console (col tuo programma del punto 1), fai un altro ciclo for sul vettore e ad ogni iterazione sommi il valore i-esimo del vettore ad una variabile, chiamiamola int somma, dichiarata fuori dal ciclo. Poi fai la media dividendo la somma per n. Sei uno studente delle superiori?
vendettaaaaa è offline   Rispondi citando il messaggio o parte di esso
Old 03-02-2014, 11:41   #6
gianmpu
Senior Member
 
Iscritto dal: Oct 2010
Messaggi: 1609
Per il punto 2), visualizzarli in ordine inverso vuol dire al contrario rispetto all'ordine in cui sono stati inseriti oppure vuol dire dal più grande al più piccolo? Se è il primo caso, va bene come ti è stato già detto. Se invece devi stamparli dal più grande al più piccolo, la soluzione più semplice è ordinare gli elementi del vettore e poi stampare semplicemente il vettore ordinato
gianmpu è offline   Rispondi citando il messaggio o parte di esso
Old 04-02-2014, 16:30   #7
uscrocc
Member
 
Iscritto dal: Feb 2014
Messaggi: 60
Quote:
Originariamente inviato da vendettaaaaa Guarda i messaggi
Scusa ma il punto 1 l'hai fatto tu per davvero...?
Il punto 4 sarebbe così: dopo aver letto i valori da console (col tuo programma del punto 1), fai un altro ciclo for sul vettore e ad ogni iterazione sommi il valore i-esimo del vettore ad una variabile, chiamiamola int somma, dichiarata fuori dal ciclo. Poi fai la media dividendo la somma per n. Sei uno studente delle superiori?
Questo e' quello che ho capito e sono riuscito a fare:


#include <iostream>
using namespace std;
void numeri1(int vet[], int n, int somma );
int main()
{
int v1[100], m, s;
cout<<"Inserisci un elemento minore di 30"<<endl;
cin>>m;
if (m>30) {
return 0;
}
numeri1(v1,m,s);
return 0;
}

void numeri1(int vet[], int n, int somma)
{

for (int i=0; i<n; i++)
{
cout<<"Inserire elemento del vettore"<<endl;
cin>>vet[i];
}
for (int i=0; i<n; i++)
{
somma = vet[i] + somma;
cout<<"la somma e'"<<somma<<endl;
}



}
uscrocc è offline   Rispondi citando il messaggio o parte di esso
Old 04-02-2014, 18:36   #8
gianmpu
Senior Member
 
Iscritto dal: Oct 2010
Messaggi: 1609
Ma tu devi fare questi esercizi in C oppure in C++?
L'approccio che stai usando infatti è basato su una serie di funzioni C con qualche comando C++.
gianmpu è offline   Rispondi citando il messaggio o parte di esso
Old 04-02-2014, 19:15   #9
clockover
Senior Member
 
L'Avatar di clockover
 
Iscritto dal: Oct 2004
Messaggi: 1945
Codice:
#include < iostream >
using namespace std;
void numeri1(int vet[], int n, int somma);
int main() {
    int v1[100], m, s;
    cout << "Inserisci un elemento minore di 30" << endl;
    cin >> m;
    if (m > 30) {
        return 0;
    }
    numeri1(v1, m, s);
    return 0;
}

void numeri1(int vet[], int n, int somma) {

    for (int i = 0; i < n; i++) {
        cout << "Inserire elemento del vettore" << endl;
        cin >> vet[i];
    }
    for (int i = 0; i < n; i++) {
        somma = vet[i] + somma;
        cout << "la somma e'" << somma << endl;
    }
}
Sarò fissato ma io il codice non indentato non ce la faccio a vederlo.... indenta il codice tra il tag CODE per piacere

Poi... cerca di essere ordinato.. cosa vuol dire il nome della funzione "numeri1"?? Se il tuo professore legge cosa deve capire? Cosa vorresti fare in quella funzione? Struttura il tutto in funzioni.
Ad esempio
Codice:
int somma(array, size){
    somma = 0
    for i to size:
        somma = .....
    return somma
}
clockover è offline   Rispondi citando il messaggio o parte di esso
Old 04-02-2014, 20:55   #10
uscrocc
Member
 
Iscritto dal: Feb 2014
Messaggi: 60
Gli altri sono riuscito a farli. Mi manca il 2 che propio non riesco! Uso Dev c++ e il linguaggio è c++
uscrocc è offline   Rispondi citando il messaggio o parte di esso
Old 04-02-2014, 22:37   #11
sharkkk
Member
 
L'Avatar di sharkkk
 
Iscritto dal: Oct 2013
Messaggi: 158
Quote:
Originariamente inviato da uscrocc Guarda i messaggi
Gli altri sono riuscito a farli. Mi manca il 2 che propio non riesco! Uso Dev c++ e il linguaggio è c++
ciao uscrocc,

il due è semplicissimo.

basta iterare (ciclare) l'array al contrario, come ti ha detto vendettaa. (cioè fare un for o un while con l'indice posizionato all'ultimo elemento dell'array, *n-1 )

Codice:
da  (n-1) fino a (n = 0)
    stampa array[n]
immaginati di essere il commesso di una banca e di avere davanti a te una fila di 20 persone, tutti in fila indiana.
se il tuo capo ti chiedesse di iniziare a servirli partendo dall'ultimo cosa faresti?
sapendo che sono 20 (l'indice), chiameresti il numero 20, poi il 19, 18...fino allo 0.

* perchè l'indice è n - 1? perche se tu inserisci un solo elemento nell'array, non lo inserisci in posizione array[1] ma in posizione array[0]. spero di essere stato chiaro e se hai dubbi continua a chiedere pure

piu semplice di cosi
sharkkk è offline   Rispondi citando il messaggio o parte di esso
Old 04-02-2014, 22:54   #12
clockover
Senior Member
 
L'Avatar di clockover
 
Iscritto dal: Oct 2004
Messaggi: 1945
E per darti un ulteriore aiuto ragiona sul ciclo for

Codice:
for(int i = 0; i < N; i++)
ovviamente sai già cosa vuol dire
1) inizializza i = 0;
2) i < N ? se si esegue il comando altrimenti esce
3) incrementa i di 1
4) torna al punto 2

Usa questa roba con quello che ti ha detto sharkkk e sei a cavallo
clockover è offline   Rispondi citando il messaggio o parte di esso
Old 05-02-2014, 01:22   #13
gianmpu
Senior Member
 
Iscritto dal: Oct 2010
Messaggi: 1609
Se si deve risolvere il problema usando il C++ e non il C, però un approccio più coerente sarebbe basato sulla creazione di una classe e dei suoi metodi più che sulla creazione di funzioni (che sono tipicamente elementi del C)
gianmpu è offline   Rispondi citando il messaggio o parte di esso
Old 06-02-2014, 01:05   #14
AnonimoVeneziano
Senior Member
 
L'Avatar di AnonimoVeneziano
 
Iscritto dal: Aug 2001
Città: San Francisco, CA, USA
Messaggi: 13827
Quote:
Originariamente inviato da gianmpu Guarda i messaggi
Se si deve risolvere il problema usando il C++ e non il C, però un approccio più coerente sarebbe basato sulla creazione di una classe e dei suoi metodi più che sulla creazione di funzioni (che sono tipicamente elementi del C)
Sta roba sarebbe da implementare tutta nel main, figuriamoci se adesso per sommare 4 numeri bisogna definire ed instanziare degli oggetti ...
__________________
GPU Compiler Engineer
AnonimoVeneziano è offline   Rispondi citando il messaggio o parte di esso
Old 06-02-2014, 19:39   #15
gianmpu
Senior Member
 
Iscritto dal: Oct 2010
Messaggi: 1609
Infatti stiamo parlando di un esercizio scolastico da scuola superiore non di un vero programma.
Se uno studente è all'inizio, si cerca di fargli apprendere i costrutti principali del linguaggio di programmazione facendoglieli applicare in situazioni molto semplici, anche se sembra di andare a pesca di trote con una baleniera.
gianmpu è offline   Rispondi citando il messaggio o parte di esso
 Rispondi


Le novità MSI del 2026 per i videogiocatori Le novità MSI del 2026 per i videogiocato...
I nuovi schermi QD-OLED di quinta generazione di MSI, per i gamers I nuovi schermi QD-OLED di quinta generazione di...
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...
Dell UltraSharp: al CES 2026 il primo mo...
LG presenta i nuovi Gram Pro con lega Ae...
LG NanoCell 65'' a 499€: il 4K di qualit...
La Befana vien di notte, anche su Amazon...
Realme 12 4G 8GB/128GB a un prezzo folle...
DJI Mini 4 Pro Fly More Combo scende a s...
C'è un monitor Dell 24" Full...
HP Digital Passport, integrazione Copilo...
HP EliteBook X G2 ed EliteBoard G1a uffi...
Tutti possono avere un Alienware: al CES...
La gamma XPS di Dell si rinnova completa...
HyperX OMEN: ufficiali 3 nuovi laptop, 4...
HP presenta al CES 2026 la nuova gamma d...
Nuova Audi A2 e-tron: la compatta elettr...
Anche a Roma arriva la Zona 30: limite d...
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: 16:13.


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