Torna indietro   Hardware Upgrade Forum > Software > Programmazione

Le soluzioni FSP per il 2026: potenza e IA al centro
Le soluzioni FSP per il 2026: potenza e IA al centro
In occasione del Tech Tour 2025 della European Hardware Association abbiamo incontrato a Taiwan FSP, azienda impegnata nella produzione di alimentatori, chassis e soluzioni di raffreddamento tanto per clienti OEM come a proprio marchio. Potenze sempre più elevate negli alimentatori per far fronte alle necessità delle elaborazioni di intelligenza artificiale.
AWS annuncia European Sovereign Cloud, il cloud sovrano per convincere l'Europa
AWS annuncia European Sovereign Cloud, il cloud sovrano per convincere l'Europa
AWS è il principale operatore di servizi cloud al mondo e da tempo parla delle misure che mette in atto per garantire una maggiore sovranità alle organizzazioni europee. L'azienda ha ora lanciato AWS European Sovereign Cloud, una soluzione specificamente progettata per essere separata e distinta dal cloud "normale" e offrire maggiori tutele e garanzie di sovranità
Redmi Note 15 Pro+ 5G: autonomia monstre e display luminoso, ma il prezzo è alto
Redmi Note 15 Pro+ 5G: autonomia monstre e display luminoso, ma il prezzo è alto
Xiaomi ha portato sul mercato internazionale la nuova serie Redmi Note, che rappresenta spesso una delle migliori scelte per chi non vuole spendere molto. Il modello 15 Pro+ punta tutto su una batteria capiente e su un ampio display luminoso, sacrificando qualcosa in termini di potenza bruta e velocità di ricarica
Tutti gli articoli Tutte le news

Vai al Forum
Rispondi
 
Strumenti
Old 19-09-2011, 00: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 19-09-2011, 00: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, 09: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, 09: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, 10: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 10:47.
>Alexan< è offline   Rispondi citando il messaggio o parte di esso
Old 19-09-2011, 10: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, 10: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, 12: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, 14: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


Le soluzioni FSP per il 2026: potenza e IA al centro Le soluzioni FSP per il 2026: potenza e IA al ce...
AWS annuncia European Sovereign Cloud, il cloud sovrano per convincere l'Europa AWS annuncia European Sovereign Cloud, il cloud ...
Redmi Note 15 Pro+ 5G: autonomia monstre e display luminoso, ma il prezzo è alto Redmi Note 15 Pro+ 5G: autonomia monstre e displ...
HONOR Magic 8 Pro: ecco il primo TOP del 2026! La recensione HONOR Magic 8 Pro: ecco il primo TOP del 2026! L...
Insta360 Link 2 Pro e 2C Pro: le webcam 4K che ti seguono, anche con gimbal integrata Insta360 Link 2 Pro e 2C Pro: le webcam 4K che t...
iPhone Air 2 in arrivo già nel 20...
Vimeo quasi svuotata: Bending Spoons ann...
Altro che bolla: per Huang l'AI è...
Battlefield 6: la Stagione 2 segner&agra...
Da Sony due nuovi giradischi wireless pe...
Arriva l'addio definitivo di Intel ad Al...
Attacco AI su Google Calendar: Gemini pu...
Renault vuole reintegrare Ampere nel gru...
1Password introduce un nuovo avviso anti...
Windows 11, nuovo bug blocca le app: col...
Tre sistemi operativi in uno smartphone:...
Crypto in Italia: 2,8 milioni di possess...
Pubblicato 'il carattere' di Claude: uti...
Siri cambia volto su iOS 27 e macOS 27: ...
Apple contro Intel e AMD: i numeri che r...
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: 01:01.


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