Torna indietro   Hardware Upgrade Forum > Software > Programmazione

Destiny Rising: quando un gioco mobile supera il gioco originale
Destiny Rising: quando un gioco mobile supera il gioco originale
Tra il declino di Destiny 2 e la crisi di Bungie, il nuovo titolo mobile sviluppato da NetEase sorprende per profondità e varietà. Rising offre ciò che il live service di Bungie non riesce più a garantire, riportando i giocatori in un universo coerente. Un confronto che mette in luce i limiti tecnici e strategici dello studio di Bellevue
Plaud Note Pro convince per qualità e integrazione, ma l’abbonamento resta un ostacolo
Plaud Note Pro convince per qualità e integrazione, ma l’abbonamento resta un ostacolo
Plaud Note Pro è un registratore digitale elegante e tascabile con app integrata che semplifica trascrizioni e riepiloghi, offre funzioni avanzate come template e note intelligenti, ma resta vincolato a un piano a pagamento per chi ne fa un uso intensivo
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.
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


Destiny Rising: quando un gioco mobile supera il gioco originale Destiny Rising: quando un gioco mobile supera il...
Plaud Note Pro convince per qualità e integrazione, ma l’abbonamento resta un ostacolo Plaud Note Pro convince per qualità e int...
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ù...
AV2 in arrivo entro fine anno: il nuovo ...
Echo, Kindle e Fire TV: Amazon prepara u...
Shai-Hulud è il worm auto-replica...
Stop a benzina e diesel dal 2035, ecco c...
Gli strumenti di scrittura AI arrivano s...
Tesla tenta l'azzardo in Europa: produzi...
OpenAI cerca un esperto di contenuti: ha...
Consumer Reports attacca Microsoft: 'Con...
Lo strumento salva-guai che ogni automob...
Le copie fisiche dei giochi non valgono ...
Apple corregge una pericolosa vulnerabil...
Honda svela WN7, la prima moto elettrica...
Ford taglia altri 1.000 posti in Germani...
Apple Sports arriva in Italia: l'app gra...
Il CEO di Gearbox ai videogiocatori: Bor...
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: 10:46.


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