Torna indietro   Hardware Upgrade Forum > Software > Programmazione

Tastiera gaming MSI GK600 TKL: switch hot-swap, display LCD e tre modalità wireless
Tastiera gaming MSI GK600 TKL: switch hot-swap, display LCD e tre modalità wireless
MSI FORGE GK600 TKL WIRELESS: switch lineari hot-swap, tripla connettività, display LCD e 5 strati di fonoassorbimento. Ottima in gaming, a 79,99 euro
DJI Osmo Pocket 4: la gimbal camera tascabile cresce e ha nuovi controlli fisici
DJI Osmo Pocket 4: la gimbal camera tascabile cresce e ha nuovi controlli fisici
DJI porta un importante aggiornamento alla sua linea di gimbal camera tascabili con Osmo Pocket 4: sensore CMOS da 1 pollice rinnovato, gamma dinamica a 14 stop, profilo colore D-Log a 10 bit, slow motion a 4K/240fps e 107 GB di archiviazione integrata. Un prodotto pensato per i creator avanzati, ma che convince anche per l'uso quotidiano
Sony INZONE H6 Air: il primo headset open-back di Sony per giocatori
Sony INZONE H6 Air: il primo headset open-back di Sony per giocatori
Il primo headset open-back della linea INZONE arriva a 200 euro con driver derivati dalle cuffie da studio MDR-MV1 e un peso record di soli 199 grammi
Tutti gli articoli Tutte le news

Vai al Forum
Rispondi
 
Strumenti
Old 29-07-2008, 14:10   #1
ciottano
Senior Member
 
L'Avatar di ciottano
 
Iscritto dal: Apr 2003
Messaggi: 6479
[C++]Questo programma mi crasha

Salve a tutti.
Ho un problema con i vettori in C++.

Ho scritto questo programmino che riempie un vettore lungo n, lo ordina e ne mostra a schermo gli elementi.

Compila senza errori. Lanciandolo mi fa riempire il vettore ma poi mi crasha.

Se invece di dichiarare un vettore generico ne dichiaro uno di lunghezza prefissata va tutto liscio.

Uso Dev sotto WinXP.

Riporto sotto il codice.

Ciao,
G.
Codice:
#include <iostream>
#include <vector>

using namespace std;

//funzione per riecmpire il vettore 
void carica(int n,vector<int> v){
//void carica(int n,int v[]){
     int i;
     int prova;          
     cout<<"inserire i voti"<<endl;
     for(i=0;i<n;i++) {
     cin>>prova;
     v.push_back(prova);
     }
}
//funzione per ordinare gli elementi del vettore
//void ordina(int n,int v[]){
void ordina(int n,vector<int> v){
     int i,j;
     int temp;
     for(i=0;i<n-1;i++)
         for(j=i+1;j<n;j++){
         if(v[i]>v[j]){
                       temp=v[i];
                       v[i]=v[j];
                       v[j]=temp;
                       }
         }
}
int main(){
    //int voti[10];
    vector<int> voti;
    int n;
    int j;
    int m;
    float med;
    float somma=0;
    cout<<"inserire numero voti"<<endl;
    cin>> n;
    carica(n,voti);
    ordina(n,voti);
    for(j=0;j<n;j++) cout<<"voti "<<voti[j]<<endl;
    //for(m=1;m<9;m++)
    for(m=1;m<n-1;m++) somma=voti[m]+somma;
    med=somma/(n-2);
    cout<<"la media e' "<<med<<endl;
    system("pause");
}
__________________
Roma: affitto stanza ammobiliata a ragazzo/a lavoratore/ice e/o studente/ssa adiacente metro. Mandatemi un pvt o mail
Sono Dott. in Fisica: offro lezioni in matematica e fisica a ragazzi dalle elementari fino all'università a Roma Nord, prezzi modici
Utente da evitare: fabyor

Ultima modifica di ciottano : 29-07-2008 alle 15:52.
ciottano è offline   Rispondi citando il messaggio o parte di esso
Old 29-07-2008, 15:38   #2
sottovento
Senior Member
 
L'Avatar di sottovento
 
Iscritto dal: Nov 2005
Città: Texas
Messaggi: 1722
Ciao,
innanzitutto cambia il titolo aggiungendo in [C++] in testa prima che ti scoprano (vabbe', c'e' scritto che e' un crash quindi puo' esser solo C/C++ )

Riguardo al crash: quando usi i vector (e li passi alle funzioni), non hai dato la possibilita' di MODIFICARLI all'interno della funzione! Il compilatore fara' una copia del vettore e lo passera' alle funzioni carica() e ordina().
Una volta completata l'esecuzione delle funzioni in oggetto, non ci sara' ovviamente una copia al contrario. Ecco che quindi accederai, sia in ordinamento sia in stampa, ad elementi che non esistono.

Ciao
__________________
In God we trust; all others bring data
sottovento è offline   Rispondi citando il messaggio o parte di esso
Old 29-07-2008, 15:51   #3
ciottano
Senior Member
 
L'Avatar di ciottano
 
Iscritto dal: Apr 2003
Messaggi: 6479
Quote:
Originariamente inviato da sottovento Guarda i messaggi
Ciao,
innanzitutto cambia il titolo aggiungendo in [C++] in testa prima che ti scoprano (vabbe', c'e' scritto che e' un crash quindi puo' esser solo C/C++ )

Riguardo al crash: quando usi i vector (e li passi alle funzioni), non hai dato la possibilita' di MODIFICARLI all'interno della funzione! Il compilatore fara' una copia del vettore e lo passera' alle funzioni carica() e ordina().
Una volta completata l'esecuzione delle funzioni in oggetto, non ci sara' ovviamente una copia al contrario. Ecco che quindi accederai, sia in ordinamento sia in stampa, ad elementi che non esistono.

Ciao
E per fare una copia in uscita da carica in modo da poterla passare ad ordina?
Cmq se non uso un vettore di dimensione indefinita ma lo dichiaro di lunghezza, chessò, 10, non ho problemi e tutto fila liscio. Quindi non credo che dipenda dal fatto che non mi ridia una copia in uscita dalle funzioni.

Grazie,
ciao,
G.
__________________
Roma: affitto stanza ammobiliata a ragazzo/a lavoratore/ice e/o studente/ssa adiacente metro. Mandatemi un pvt o mail
Sono Dott. in Fisica: offro lezioni in matematica e fisica a ragazzi dalle elementari fino all'università a Roma Nord, prezzi modici
Utente da evitare: fabyor
ciottano è offline   Rispondi citando il messaggio o parte di esso
Old 29-07-2008, 16:08   #4
sottovento
Senior Member
 
L'Avatar di sottovento
 
Iscritto dal: Nov 2005
Città: Texas
Messaggi: 1722
Quote:
Originariamente inviato da ciottano Guarda i messaggi
E per fare una copia in uscita da carica in modo da poterla passare ad ordina?
Cmq se non uso un vettore di dimensione indefinita ma lo dichiaro di lunghezza, chessò, 10, non ho problemi e tutto fila liscio. Quindi non credo che dipenda dal fatto che non mi ridia una copia in uscita dalle funzioni.

Grazie,
ciao,
G.
No, non devi fare una copia in uscita. Semplicemente non devi fare nessuna copia, nemmeno in entrata. Oltretutto ci guadagni in efficienza

Aggiungi un simbolo & (spero che si veda, non vorrei sia interpretato in maniera strana) alle dichiarazioni. Cosi' come li hai dichiarati, quei vettori (vector, intendo) sono solamente variabili di ingresso.

Diverso e' quando usi il vettore[] poiche' passi un indirizzo...
__________________
In God we trust; all others bring data
sottovento è offline   Rispondi citando il messaggio o parte di esso
Old 29-07-2008, 16:32   #5
banryu79
Senior Member
 
L'Avatar di banryu79
 
Iscritto dal: Oct 2007
Città: Padova
Messaggi: 4131
In pratica sottovento ti sta suggerendo di passare come parametro la reference al vettore (operatore &): in questo modo, nel contesto della funzione verrà passato l'indirizzo del tuo vettore e le operazioni che quella funzione ci farà sopra modificheranno il tuo vettore.

Altrimenti, come ha già spiegato sottovento, il passaggio del parametro avviene per copia: all'interno della funzione verrà manipolata una copia del vettore, che esiste solo nello scope della funzione. All'esterno il tuo vettore risulterà immutato.
__________________

As long as you are basically literate in programming, you should be able to express any logical relationship you understand.
If you don’t understand a logical relationship, you can use the attempt to program it as a means to learn about it.
(Chris Crawford)
banryu79 è offline   Rispondi citando il messaggio o parte di esso
Old 29-07-2008, 16:36   #6
ciottano
Senior Member
 
L'Avatar di ciottano
 
Iscritto dal: Apr 2003
Messaggi: 6479
Bene, grazie ad entrambi, ora ho capito il problema.

Provo e vi faccio sapere il risultato.

G.
__________________
Roma: affitto stanza ammobiliata a ragazzo/a lavoratore/ice e/o studente/ssa adiacente metro. Mandatemi un pvt o mail
Sono Dott. in Fisica: offro lezioni in matematica e fisica a ragazzi dalle elementari fino all'università a Roma Nord, prezzi modici
Utente da evitare: fabyor
ciottano è offline   Rispondi citando il messaggio o parte di esso
Old 29-07-2008, 16:56   #7
ciottano
Senior Member
 
L'Avatar di ciottano
 
Iscritto dal: Apr 2003
Messaggi: 6479
Ho risolto aggiungendo & come suggeritomi da sottovento.

Grazie ancora ad entrambi,
G.
__________________
Roma: affitto stanza ammobiliata a ragazzo/a lavoratore/ice e/o studente/ssa adiacente metro. Mandatemi un pvt o mail
Sono Dott. in Fisica: offro lezioni in matematica e fisica a ragazzi dalle elementari fino all'università a Roma Nord, prezzi modici
Utente da evitare: fabyor
ciottano è offline   Rispondi citando il messaggio o parte di esso
 Rispondi


Tastiera gaming MSI GK600 TKL: switch hot-swap, display LCD e tre modalità wireless Tastiera gaming MSI GK600 TKL: switch hot-swap, ...
DJI Osmo Pocket 4: la gimbal camera tascabile cresce e ha nuovi controlli fisici DJI Osmo Pocket 4: la gimbal camera tascabile cr...
Sony INZONE H6 Air: il primo headset open-back di Sony per giocatori Sony INZONE H6 Air: il primo headset open-back d...
Nutanix cambia pelle: dall’iperconvergenza alla piattaforma full stack per cloud ibrido e IA Nutanix cambia pelle: dall’iperconvergenza alla ...
Recensione Xiaomi Pad 8 Pro: potenza bruta e HyperOS 3 per sfidare la fascia alta Recensione Xiaomi Pad 8 Pro: potenza bruta e Hyp...
Svendita MacBook Pro: c'è il mode...
Oggi questa TV TCL QLED da 43 pollici co...
Il caricatore multiplo da 200W che va be...
Top 7 Amazon, il meglio del meglio di qu...
Spento lo strumento LECP della sonda spa...
Voyager Technologies ha siglato un accor...
GoPro annuncia la linea MISSION 1 con tr...
Alcune varianti dei futuri Samsung Galax...
Il ridimensionamento di OnePlus in Europ...
Il cofondatore di Netflix ha lasciato l'...
ASUS porta in Italia il nuovo Zenbook Du...
Assassin's Creed: Black Flag Resynced, s...
Xbox Game Pass cambierà: tra le n...
I nuovi Surface Pro e Laptop sono vicini...
OnePlus ci riprova con la fascia bassa: ...
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: 12:02.


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