Torna indietro   Hardware Upgrade Forum > Software > Programmazione

Wi-Fi 7 con il design di una vetta innevata: ecco il nuovo sistema mesh di Huawei
Wi-Fi 7 con il design di una vetta innevata: ecco il nuovo sistema mesh di Huawei
HUAWEI WiFi Mesh X3 Pro Suite è probabilmente il router mesh più fotogenico che si possa acquistare oggi in Italia, ma dietro il guscio in acrilico trasparente e le luci LED dinamiche c'è una macchina tecnica costruita attorno allo standard Wi-Fi 7, con velocità teoriche Dual-Band fino a 3,6 Gbps e una copertura fino a 120 m² una volta abbinato il router principale all'extender incluso nel kit
Core Ultra 7 270K Plus e Core Ultra 7 250K Plus: Intel cerca il riscatto ma ci riesce in parte
Core Ultra 7 270K Plus e Core Ultra 7 250K Plus: Intel cerca il riscatto ma ci riesce in parte
Abbiamo provato le nuove CPU Intel Core Ultra 7 270K Plus e Core Ultra 7 250K Plus: più core e ottimizzazioni al funzionamento interno migliorano le prestazioni, anche in virtù di prezzi annunciati interessanti. A questo si aggiungono nuove ottimizzazioni software. Purtroppo, a fronte di prestazioni di calcolo elevate, il quadro rimane incerto nel gaming, dove l'andamento rimane altalenante. Infine, rimane il problema della piattaforma a fine vita.
PC Specialist Lafité 14 AI AMD: assemblato come vuoi tu
PC Specialist Lafité 14 AI AMD: assemblato come vuoi tu
Il modello "build to order" di PCSpecialist permette di selezionare una struttura base per un sistema, personalizzandolo in base alle specifiche esigenze con una notevole flessibilità di scelta tra i componenti. Il modello Lafité 14 AI AMD è un classico notebook clamshell compatto e potente, capace di assicurare una elevata autonomia di funzionamento anche lontano dalla presa di corrente
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


Wi-Fi 7 con il design di una vetta innevata: ecco il nuovo sistema mesh di Huawei Wi-Fi 7 con il design di una vetta innevata: ecc...
Core Ultra 7 270K Plus e Core Ultra 7 250K Plus: Intel cerca il riscatto ma ci riesce in parte Core Ultra 7 270K Plus e Core Ultra 7 250K Plus:...
PC Specialist Lafité 14 AI AMD: assemblato come vuoi tu PC Specialist Lafité 14 AI AMD: assemblat...
Recensione Nothing Phone 4(a): sempre iconico ma ora più concreto Recensione Nothing Phone 4(a): sempre iconico ma...
Corsair Vanguard Air 99 Wireless: non si era mai vista una tastiera gaming così professionale Corsair Vanguard Air 99 Wireless: non si era mai...
La NASA dimostrerà l'utilizzo del...
L'ESA acquisterà una missione Cre...
La NASA cambia idea sulle stazioni spazi...
Implementazione NVMe nativa disattivata ...
Polestar 2 e 3: le batterie integrano or...
Crisi delle memorie: ecco le soluzioni p...
Il satellite ESA Proba-3 è tornat...
'Chiudete (quasi) tutto', il risultato d...
Tesla, maggiore autonomia grazie a una r...
Nasce TrendAI, la divisione di Trend Mic...
Recensione Motorola Signature: il primo ...
TeraFab, Elon Musk parte all'assalto di ...
L'ambiziosa base lunare permanente sulla...
Litografia BEUV (Beyond-EUV): la startup...
SAP e l'IA agentica: dall'hype alla matu...
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: 07:06.


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