Torna indietro   Hardware Upgrade Forum > Software > Programmazione

Google Pixel 10 è compatto e ha uno zoom 5x a 899€: basta per essere un best-buy?
Google Pixel 10 è compatto e ha uno zoom 5x a 899€: basta per essere un best-buy?
Google Pixel 10 è uno smartphone che unisce una fotocamera molto più versatile rispetto al passato grazie allo zoom ottico 5x, il supporto magnetico Pixelsnap e il nuovo chip Tensor G5. Il dispositivo porta Android 16 e funzionalità AI avanzate come Camera Coach, mantenendo il design caratteristico della serie Pixel con miglioramenti nelle prestazioni e nell'autonomia. In Italia, però, mancano diverse feature peculiari basate sull'AI.
Prova GeForce NOW upgrade Blackwell: il cloud gaming cambia per sempre
Prova GeForce NOW upgrade Blackwell: il cloud gaming cambia per sempre
L'abbonamento Ultimate di GeForce NOW ora comprende la nuova architettura Blackwell RTX con GPU RTX 5080 che garantisce prestazioni tre volte superiori alla precedente generazione. Non si tratta solo di velocità, ma di un'esperienza di gioco migliorata con nuove tecnologie di streaming e un catalogo giochi raddoppiato grazie alla funzione Install-to-Play
Ecovacs Deebot X11 Omnicyclone: niente più sacchetto per lo sporco
Ecovacs Deebot X11 Omnicyclone: niente più sacchetto per lo sporco
Deebot X11 Omnicyclone implementa tutte le ultime tecnologie Ecovacs per l'aspirazione dei pavimenti di casa e il loro lavaggio, con una novità: nella base di ricarica non c'è più il sacchetto di raccolta dello sporco, sostituito da un aspirapolvere ciclonico che accumula tutto in un contenitore rigido
Tutti gli articoli Tutte le news

Vai al Forum
Rispondi
 
Strumenti
Old 18-09-2011, 23:07   #1
>Alexan<
Member
 
L'Avatar di >Alexan<
 
Iscritto dal: Feb 2006
Città: Bracciano (RM)
Messaggi: 243
[C++] Errore di segmentazione

ho fatto un programmino semplice semplice per calcolare la norma di un vettore...
il codice è il seguente:

Codice:
#include <iostream>
#include <iomanip>
#include <cmath>

using namespace std;

typedef double vettore[21];

void leggi_int(int&);
void leggi_vettore(vettore,int);
double norm2(vettore,int);

main()
{
  int n,i;double norma;vettore v;
  leggi_int(n);
  leggi_vettore(v,n);
  norma=norm2(v,n);
  cout << setprecision(19) << norma << endl;
  return 0;
}

void leggi_int(int& n)
{
  cout << "\n\n  inserire un numero intero maggiore di uno e minore di 20\n\n     ";cin >> n;
  if ((n<2)||(n>19))
    {
      cout << "\n\n  il valore inserito non è accettabile!!!";
      return leggi_int(n);
    }
  return;
}

void leggi_vettore(vettore v,int n)
{
  int i;
  for (i=1;i<=n;i++)
    {
      cout << "\n  inserire la componente numero " << i << "\n     ";cin >> v[i];
    }
  return;
}

double norm2(vettore v,int n)
{
  int i;double norma=0;
  for (i=1;1<=n;i++) norma=norma+v[i]*v[i];  // l'errore è qui!!
  norma=sqrt(norma);
  return norma;
}
quando vado a compilare mi dà errore di segmentazione... dovrebbe essere alla riga che ho segnato nel corpo della funzione "norm2", ma non riesco a capire perchè sia sbagliato...
qualcuno può darmi una mano??
__________________
My Mod
>Alexan< è offline   Rispondi citando il messaggio o parte di esso
Old 18-09-2011, 23:26   #2
Freaxxx
Senior Member
 
L'Avatar di Freaxxx
 
Iscritto dal: Dec 2006
Messaggi: 3808
Quote:
Originariamente inviato da >Alexan< Guarda i messaggi
ho fatto un programmino semplice semplice per calcolare la norma di un vettore...
il codice è il seguente:

Codice:
#include <iostream>
#include <iomanip>
#include <cmath>

using namespace std;

typedef double vettore[21];

void leggi_int(int&);
void leggi_vettore(vettore,int);
double norm2(vettore,int);

main()
{
  int n,i;double norma;vettore v;
  leggi_int(n);
  leggi_vettore(v,n);
  norma=norm2(v,n);
  cout << setprecision(19) << norma << endl;
  return 0;
}

void leggi_int(int& n)
{
  cout << "\n\n  inserire un numero intero maggiore di uno e minore di 20\n\n     ";cin >> n;
  if ((n<2)||(n>19))
    {
      cout << "\n\n  il valore inserito non è accettabile!!!";
      return leggi_int(n);
    }
  return;
}

void leggi_vettore(vettore v,int n)
{
  int i;
  for (i=1;i<=n;i++)
    {
      cout << "\n  inserire la componente numero " << i << "\n     ";cin >> v[i];
    }
  return;
}

double norm2(vettore v,int n)
{
  int i;double norma=0;
  for (i=1;1<=n;i++) norma=norma+v[i]*v[i];  // l'errore è qui!!
  norma=sqrt(norma);
  return norma;
}
quando vado a compilare mi dà errore di segmentazione... dovrebbe essere alla riga che ho segnato nel corpo della funzione "norm2", ma non riesco a capire perchè sia sbagliato...
qualcuno può darmi una mano??
prova a mettere quel v[i] tra parentesi tonde insieme al v[i] che precede

Codice:
for (i=1;1<=n;i++) norma=norma+(v[i])*(v[i]);
Freaxxx è offline   Rispondi citando il messaggio o parte di esso
Old 19-09-2011, 08:23   #3
marco.r
Senior Member
 
Iscritto dal: Dec 2005
Città: Istanbul
Messaggi: 1817
Quote:
Originariamente inviato da >Alexan< Guarda i messaggi
ho fatto un programmino semplice semplice per calcolare la norma di un vettore...
il codice è il seguente:

Codice:
  for (i=1;i<=n;i++)
    {
      cout << "\n  inserire la componente numero " << i << "\n     ";cin >> v[i];
    }
In C++ gli indici di un vettore di dimensione N vanno da 0 a N-1, non da 1 a N
I cicli for andrebbero riscritti come
Codice:
for (int i=0; i<n; ++i)
// ...
__________________
One of the conclusions that we reached was that the "object" need not be a primitive notion in a programming language; one can build objects and their behaviour from little more than assignable value cells and good old lambda expressions. —Guy Steele
marco.r è offline   Rispondi citando il messaggio o parte di esso
Old 19-09-2011, 08:59   #4
ESSE-EFFE
Member
 
Iscritto dal: May 2009
Messaggi: 186
Attenzione:

Quote:
Originariamente inviato da >Alexan< Guarda i messaggi
Codice:
double norm2(vettore v,int n)
{
  int i;double norma=0;
  for (i=1;1<=n;i++) norma=norma+v[i]*v[i];  // l'errore è qui!!
  norma=sqrt(norma);
  return norma;
}
__________________
ESSE-EFFE.com
Sviluppo software e Web
Creazione loghi - Bergamo
ESSE-EFFE è offline   Rispondi citando il messaggio o parte di esso
Old 19-09-2011, 09:42   #5
>Alexan<
Member
 
L'Avatar di >Alexan<
 
Iscritto dal: Feb 2006
Città: Bracciano (RM)
Messaggi: 243
lo so, ma ho definito la variabile vettore come un array che ha dimensione sempre di almeno n+1, appunto per comodità nel definire i cicli!
anche correggendo il programma come dite voi l'errore c'è lo stesso!

P.S. @Freaxxx: ho provato anche a mettere le parentesi come hai detto tu, ma non risolve...

Scusate... non avevo visto che nell'ultimo ciclo c'è un 1 invece della i... grazie ESSE-EFFE!
__________________
My Mod

Ultima modifica di >Alexan< : 19-09-2011 alle 09:47.
>Alexan< è offline   Rispondi citando il messaggio o parte di esso
Old 19-09-2011, 09:45   #6
ESSE-EFFE
Member
 
Iscritto dal: May 2009
Messaggi: 186
Quote:
Originariamente inviato da >Alexan< Guarda i messaggi
anche correggendo il programma come dite voi l'errore c'è lo stesso!
Scusa, ma hai visto l'errore che ho evidenziato?
__________________
ESSE-EFFE.com
Sviluppo software e Web
Creazione loghi - Bergamo
ESSE-EFFE è offline   Rispondi citando il messaggio o parte di esso
Old 19-09-2011, 09:48   #7
pabloski
Senior Member
 
Iscritto dal: Jan 2008
Messaggi: 8406
Codice:
for (i=1;1<=n;i++) norma=norma+v[i]*v[i];

che erroraccio

1 <= n??? è i <= n, altrimenti logicamente va in loop e i arriva alle stelle
pabloski è offline   Rispondi citando il messaggio o parte di esso
Old 19-09-2011, 11:52   #8
>Alexan<
Member
 
L'Avatar di >Alexan<
 
Iscritto dal: Feb 2006
Città: Bracciano (RM)
Messaggi: 243
Quote:
Originariamente inviato da ESSE-EFFE Guarda i messaggi
Scusa, ma hai visto l'errore che ho evidenziato?
si si!! ho editato il messaggio prima che rispondessi di nuovo!
grazie ancora a tutti!
__________________
My Mod
>Alexan< è offline   Rispondi citando il messaggio o parte di esso
Old 19-09-2011, 13:49   #9
Emalele1688
Member
 
Iscritto dal: Oct 2009
Messaggi: 157
Gli errori di segmentazione sono la cosa per cui mi ci cemento fino all'esaurimento. Usa software di Debugging, o il debugger incluso nel tuo compilatore. Ti facilita la vita ed eviti nervi ed arrabbiature contro il tuo PC
Emalele1688 è offline   Rispondi citando il messaggio o parte di esso
 Rispondi


Google Pixel 10 è compatto e ha uno zoom 5x a 899€: basta per essere un best-buy? Google Pixel 10 è compatto e ha uno zoom ...
Prova GeForce NOW upgrade Blackwell: il cloud gaming cambia per sempre Prova GeForce NOW upgrade Blackwell: il cloud ga...
Ecovacs Deebot X11 Omnicyclone: niente più sacchetto per lo sporco Ecovacs Deebot X11 Omnicyclone: niente più...
Narwal Flow: con il mocio orizzontale lava i pavimenti al meglio Narwal Flow: con il mocio orizzontale lava i pav...
Panasonic 55Z95BEG cala gli assi: pannello Tandem e audio senza compromessi Panasonic 55Z95BEG cala gli assi: pannello Tande...
Iliad: si consolida la partnership tecno...
Il SoC a 2 nm di Samsung non sfigura nel...
Prezzo shock per i Galaxy Buds FE + nuov...
Il nuovo SoC di Qualcomm vuole stupire: ...
Offerta lampo per pulire l'auto: aspirap...
I robotaxi di Amazon entrano in azione: ...
ECOVACS DEEBOT T50 PRO OMNI Gen2 domina ...
iPhone 17 Pro su Amazon: tutti i colori,...
Disney Plus da 2,99 euro al mese per 3 m...
Nuovo test di accensione dei motori per ...
Novità dalle analisi dell'asteroi...
La PS6 sarà più potente del previsto: ec...
Sony svela Xperia 10 VII: è il nu...
Amazon Weekend da urlo: iPhone 16 a prez...
Spotify diffida ReVanced: chiesta la rim...
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: 05:19.


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