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 26-08-2014, 21:08   #1
carugo
Member
 
Iscritto dal: Oct 2008
Messaggi: 42
[C++] problema Segmentation fault

Ciao a tutti

Ho un problema con questo programmino che utilizza l 'algoritmo quicksort per ordinare un vettore di interi creati a random, in run-time mi va in crash dovuto a un segmentation fault non capisco perchè.....

Codice:
#include <cstdlib>
#include <iostream>

using namespace std;

const int QUANTI=100;

int v[QUANTI];

void stampaVet (int v[], int num_ele)
{
     for (int i=0; i<num_ele; i++)
        cout<< v[i] << "  ";
}

void quickSort( int arr[], int left, int right)
{
int i = left;
int j = right;
int y = 0;

int z = arr[(left + right)/2];

do
 {
   while(arr[i] < z) i++;
   while(z < arr[j]) j--;
   
  if (i<=j)
    { 
      y= arr[i];
      arr[i]= arr[j];
      arr[j]= y;
      i++;
      j--;
     }
  } while (i<=j);
  
    if (left < j)
       quickSort(arr,left,j);
    
    if (i < right);
       quickSort(arr,i,right);
}

void preparaVettore (int v[] , int num_ele)
 {
     for (int i=0; i<num_ele; i++)
         v[i]= rand();
  }
       

int main(int argc, char *argv[])
{
    
     preparaVettore(v,QUANTI);
     stampaVet(v,QUANTI);
     quickSort(v,0,QUANTI-1);
     stampaVet(v,QUANTI);
     
    
    system("PAUSE");
    return EXIT_SUCCESS;
}
Qualche idea?

TNX a tutti

Ultima modifica di carugo : 26-08-2014 alle 21:10.
carugo è offline   Rispondi citando il messaggio o parte di esso
Old 26-08-2014, 21:27   #2
wingman87
Senior Member
 
Iscritto dal: Nov 2005
Messaggi: 2774
Prova ad eseguire l'algoritmo con carta e penna (o anche mentalmente) con questo array:
1 2 3 4 5 1 1

C'è chiaramente qualcosa che non va... rivedi l'algoritmo del quicksort, hai dimenticato qualcosa.
wingman87 è offline   Rispondi citando il messaggio o parte di esso
Old 27-08-2014, 11:24   #3
sottovento
Senior Member
 
L'Avatar di sottovento
 
Iscritto dal: Nov 2005
Città: Texas
Messaggi: 1722
Codice:
void quickSort( int arr[], int left, int right)
{
int i = left;
int j = right;
int y = 0;

int z = arr[(left + right)/2];

do
 {
   while(arr[i] < z) i++;
   while(z < arr[j]) j--;
   
  if (i<=j)
    { 
      y= arr[i];
      arr[i]= arr[j];
      arr[j]= y;
      i++;
      j--;
     }
  } while (i<=j);
  
    if (left < j)
       quickSort(arr,left,j);
    
    if (i < right);
       quickSort(arr,i,right);
}
Zoomiamo ancora:
Codice:
    if (i < right);
Questa fa si che il tuo codice sia sempre e comunque ricorsivo, quindi 'sta routine continua a chiamare se stessa fino ad esplodere.

Togli il punto e virgola
__________________
In God we trust; all others bring data

Ultima modifica di sottovento : 27-08-2014 alle 11:27.
sottovento è offline   Rispondi citando il messaggio o parte di esso
Old 27-08-2014, 12:09   #4
wingman87
Senior Member
 
Iscritto dal: Nov 2005
Messaggi: 2774
Quello non l'avevo visto, che occhio di falco!
Ma se non ho visto male, corretto quello potrebbero esserci altri problemi.
wingman87 è offline   Rispondi citando il messaggio o parte di esso
Old 27-08-2014, 12:14   #5
gbhu
Senior Member
 
Iscritto dal: Apr 2008
Messaggi: 1242
Tutto bene con i due cicli while piazzati subito all'inizio del blocco do ?
gbhu è offline   Rispondi citando il messaggio o parte di esso
Old 27-08-2014, 13:47   #6
carugo
Member
 
Iscritto dal: Oct 2008
Messaggi: 42
Grazie a tutti raga

Stavo diventando pazzo grazie Sottovento ora tutto ok alla prossima

CIauzzzz

Ultima modifica di carugo : 27-08-2014 alle 14:40.
carugo è offline   Rispondi citando il messaggio o parte di esso
Old 27-08-2014, 19:36   #7
sottovento
Senior Member
 
L'Avatar di sottovento
 
Iscritto dal: Nov 2005
Città: Texas
Messaggi: 1722
Quote:
Originariamente inviato da wingman87 Guarda i messaggi
Quello non l'avevo visto, che occhio di falco!
Si chiama fortuna
__________________
In God we trust; all others bring data
sottovento è 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...
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...
Spazzolini elettrici Oral-B iO in super ...
Samsung Galaxy Watch8 Classic e Watch7 a...
Blue Origin prosegue lo sviluppo di Blue...
Roborock Saros 10 e 10R dominano il merc...
Apple scatenata su Amazon: tutti gli sco...
Canon EOS C50 è la nuova videocam...
ASUS ProArt P16 arriva in Italia: la wor...
Fujifilm presenta l'obiettivo FUJINON GF...
Il grafene ha appena 'infranto' una legg...
Metroid Prime Beyond: arriva un trailer ...
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: 15:45.


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