Torna indietro   Hardware Upgrade Forum > Software > Programmazione

Roborock Qrevo Curv 2 Flow: ora lava con un rullo
Roborock Qrevo Curv 2 Flow: ora lava con un rullo
Qrevo Curv 2 Flow è l'ultima novità di casa Roborock per la pulizia di casa: un robot completo, forte di un sistema di lavaggio dei pavimenti basato su rullo che si estende a seguire il profilo delle pareti abbinato ad un potente motore di aspirazione con doppia spazzola laterale
Alpine A290 alla prova: un'auto bella che ti fa innamorare, con qualche limite
Alpine A290 alla prova: un'auto bella che ti fa innamorare, con qualche limite
Abbiamo guidato per diversi giorni la Alpine A290, la prima elettrica del nuovo corso della marca. Non è solo una Renault 5 sotto steroidi, ha una sua identità e vuole farsi guidare
Recensione HONOR Magic 8 Lite: lo smartphone indistruttibile e instancabile
Recensione HONOR Magic 8 Lite: lo smartphone indistruttibile e instancabile
Abbiamo provato a fondo il nuovo Magic 8 Lite di HONOR, e per farlo siamo volati fino a Marrakech , dove abbiamo testato la resistenza di questo smartphone in ogni condizione possibile ed immaginabile. Il risultato? Uno smartphone praticamente indistruttibile e con un'autonomia davvero ottima. Ma c'è molto altro da sapere su Magic 8 Lite, ve lo raccontiamo in questa recensione completa.
Tutti gli articoli Tutte le news

Vai al Forum
Rispondi
 
Strumenti
Old 26-08-2014, 22: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 22:10.
carugo è offline   Rispondi citando il messaggio o parte di esso
Old 26-08-2014, 22:27   #2
wingman87
Senior Member
 
Iscritto dal: Nov 2005
Messaggi: 2787
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, 12: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 12:27.
sottovento è offline   Rispondi citando il messaggio o parte di esso
Old 27-08-2014, 13:09   #4
wingman87
Senior Member
 
Iscritto dal: Nov 2005
Messaggi: 2787
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, 13: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, 14: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 15:40.
carugo è offline   Rispondi citando il messaggio o parte di esso
Old 27-08-2014, 20: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


Roborock Qrevo Curv 2 Flow: ora lava con un rullo Roborock Qrevo Curv 2 Flow: ora lava con un rull...
Alpine A290 alla prova: un'auto bella che ti fa innamorare, con qualche limite Alpine A290 alla prova: un'auto bella che ti fa ...
Recensione HONOR Magic 8 Lite: lo smartphone indistruttibile e instancabile Recensione HONOR Magic 8 Lite: lo smartphone ind...
Sony WF-1000X M6: le cuffie in-ear di riferimento migliorano ancora Sony WF-1000X M6: le cuffie in-ear di riferiment...
Snowflake porta l'IA dove sono i dati, anche grazie a un accordo con OpenAI Snowflake porta l'IA dove sono i dati, anche gra...
AOC propone un QD-OLED al prezzo di un I...
AGCOM segnalerà la AI Mode di Goo...
L'Estonia porta ChatGPT in classe: firma...
2 nm giapponesi contro TSMC: il piano di...
Questa scopa elettrica Tineco iFLOOR 5 è...
FRITZ!Box 6825 4G sbarca in Italia a 129...
Red Hat presenta Digital Sovereignty Rea...
AMD Zen 6 'Olympic Ridge': sette configu...
Amazon batte Walmart dopo 30 anni: il so...
Digos nel mirino dell'intelligence cines...
Sony non vuole aumentare il prezzo della...
Energia geotermica: la (costosa) rispost...
MG ha già venduto 1 milione di au...
"Something Big Is Happening" —...
Renault chiude il 2025 con una perdita 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: 19:47.


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