Torna indietro   Hardware Upgrade Forum > Software > Programmazione

DJI Osmo Pocket 4: la gimbal camera tascabile cresce e ha nuovi controlli fisici
DJI Osmo Pocket 4: la gimbal camera tascabile cresce e ha nuovi controlli fisici
DJI porta un importante aggiornamento alla sua linea di gimbal camera tascabili con Osmo Pocket 4: sensore CMOS da 1 pollice rinnovato, gamma dinamica a 14 stop, profilo colore D-Log a 10 bit, slow motion a 4K/240fps e 107 GB di archiviazione integrata. Un prodotto pensato per i creator avanzati, ma che convince anche per l'uso quotidiano
Sony INZONE H6 Air: il primo headset open-back di Sony per giocatori
Sony INZONE H6 Air: il primo headset open-back di Sony per giocatori
Il primo headset open-back della linea INZONE arriva a 200 euro con driver derivati dalle cuffie da studio MDR-MV1 e un peso record di soli 199 grammi
Nutanix cambia pelle: dall’iperconvergenza alla piattaforma full stack per cloud ibrido e IA
Nutanix cambia pelle: dall’iperconvergenza alla piattaforma full stack per cloud ibrido e IA
Al .NEXT 2026 di Chicago, Nutanix ha mostrato quanto sia cambiata: una piattaforma software che gestisce VM, container e carichi di lavoro IA ovunque, dall’on-premise al cloud pubblico. Con un’esecuzione rapidissima sulle partnership e sulla migrazione da VMware
Tutti gli articoli Tutte le news

Vai al Forum
Rispondi
 
Strumenti
Old 30-08-2015, 16:10   #1
fracarro
Senior Member
 
L'Avatar di fracarro
 
Iscritto dal: Jul 2002
Messaggi: 869
[C++] Ricerca binaria su vettore di puntatori a struct

Salve a tutti.
Come da titolo avrei bisogno di implementare una ricerca binaria (che restituisce un iteratore e non un valore bool) per un vettori di puntatori a struttura (dichiarato come std::vector<datiArco*> vetArchi; ). La struttura dati è la seguente:
Codice:
 struct datiArco{
   int da;
   int a;
   std::vector<int> colori;
   
   bool operator<(const datiArco &other) const {
      if(this->da == other.da) return this->a < other.a;
      else return this->da < other.da;
   }
   
   bool operator==(const datiArco &other) const {
          return ((this->da == other.da) && (this->a == other.a));
   }
 };

static bool comparePtrToArc(const datiArco* ptr1, const datiArco* ptr2) {
	if(ptr1->da == ptr2->da) return (ptr1->a < ptr2->a);
	else return (ptr1->da < ptr2->da);
}
La funzione comparePtrToArc serve per il sort del vettore (e fino qui tutto ok). Leggendo su internet mi sembra possibile implementare la ricerca binaria in c++ utilizzando la funzione lower_bound. Tuttavia quando invoco la funzione tramite il seguente comando:

Codice:
datiArco arcoTmp;
arcoTmp.da = i;
arcoTmp.a = j;
std::vector<datiArco*>::iterator itArco = std::lower_bound(getVetArchi().begin(), getVetArchi().end(), &arcoTmp,comparePtrToArc);
ricevo sempre una segmentation fault proprio nella riga di invocazione della funzione lower_bound. So che utilizzare un vettore di puntatori non è consigliato ma non posso cambiare questa struttura. Qualche esperto di c++ può darmi qualche consiglio per individuare l'errore?
__________________
Notebook: MBP 15 i7 Retina, (Mid 2014)
fracarro è offline   Rispondi citando il messaggio o parte di esso
Old 31-08-2015, 23:08   #2
71106
Bannato
 
Iscritto dal: Nov 2014
Messaggi: 292
Tre osservazioni:
  1. Non mi sembra di vedere nulla di sbagliato nei due snippet, l'errore potrebbe essere nella funzione getVetArchi().
  2. L'implementazione comparePtrToArc è identica a quella dell'operatore <, quindi puoi eliminare quella funzione e affidarti sempre all'uso implicito dell'operatore, sia nel sort che nella ricerca binaria.
  3. Se ti serve solo di testare la presenza dell'elemento, e non ti serve di avere l'iteratore, puoi usare binary_search.
71106 è offline   Rispondi citando il messaggio o parte di esso
Old 03-09-2015, 21:16   #3
fracarro
Senior Member
 
L'Avatar di fracarro
 
Iscritto dal: Jul 2002
Messaggi: 869
Quote:
Originariamente inviato da 71106 Guarda i messaggi
Tre osservazioni:
  1. Non mi sembra di vedere nulla di sbagliato nei due snippet, l'errore potrebbe essere nella funzione getVetArchi().
  2. L'implementazione comparePtrToArc è identica a quella dell'operatore <, quindi puoi eliminare quella funzione e affidarti sempre all'uso implicito dell'operatore, sia nel sort che nella ricerca binaria.
  3. Se ti serve solo di testare la presenza dell'elemento, e non ti serve di avere l'iteratore, puoi usare binary_search.
Innanzitutto grazie per le risposte. Riguardo i tre punti:
1. La funzione getVetArchi() è la seguente:
Codice:
   std::vector<datiArco*> getVetArchi() const {
      return vetArchi;
   }
ossia è il metodo "getter" di una classe X che contiene il vettore di struct vetArchi definito in questo modo: std::vector<datiArco*> vetArchi;

Nel primo post non avevo indicato questo dettaglio per non complicare la descrizione del problema ma la chiamate reale nel mio codice è:
Codice:
std::vector<datiArco*>::iterator itArco = std::lower_bound(p->getVetArchi().begin(), p->getVetArchi().end(), &arcoTmp,comparePtrToArc);
dove p è un oggetto della classe X.

2. Giusto, eliminerò la funzione inutile.

3. Purtroppo è proprio quello il problema. Tutta la questione nasce dalla necessità di avere l'iteratore o l'indice dell'elemento nell'array, non mi basta sapere se l'elemento è presente o meno.
__________________
Notebook: MBP 15 i7 Retina, (Mid 2014)
fracarro è offline   Rispondi citando il messaggio o parte di esso
Old 06-09-2015, 09:56   #4
71106
Bannato
 
Iscritto dal: Nov 2014
Messaggi: 292
Quote:
Originariamente inviato da fracarro Guarda i messaggi
Innanzitutto grazie per le risposte. Riguardo i tre punti:
1. La funzione getVetArchi() è la seguente:
Codice:
   std::vector<datiArco*> getVetArchi() const {
      return vetArchi;
   }
ossia è il metodo "getter" di una classe X che contiene il vettore di struct vetArchi definito in questo modo: std::vector<datiArco*> vetArchi;

Nel primo post non avevo indicato questo dettaglio per non complicare la descrizione del problema ma la chiamate reale nel mio codice è:
Codice:
std::vector<datiArco*>::iterator itArco = std::lower_bound(p->getVetArchi().begin(), p->getVetArchi().end(), &arcoTmp,comparePtrToArc);
dove p è un oggetto della classe X.
Ora è più chiaro: getVetArchi effettua una copia del vettore, e la invochi indipendentemente per ottenere l'iteratore di inizio e quello di fine, quindi i due iteratori tra i quali la lower_bound si trova ad iterare appartengono a due vettori diversi.

Prova così:

Codice:
std::vector<datiArco*> vetArchi = p->getVetArchi();
std::vector<datiArco*>::iterator itArco = std::lower_bound(vetArchi.begin(), vetArchi.end(), &arcoTmp,comparePtrToArc);
71106 è offline   Rispondi citando il messaggio o parte di esso
 Rispondi


DJI Osmo Pocket 4: la gimbal camera tascabile cresce e ha nuovi controlli fisici DJI Osmo Pocket 4: la gimbal camera tascabile cr...
Sony INZONE H6 Air: il primo headset open-back di Sony per giocatori Sony INZONE H6 Air: il primo headset open-back d...
Nutanix cambia pelle: dall’iperconvergenza alla piattaforma full stack per cloud ibrido e IA Nutanix cambia pelle: dall’iperconvergenza alla ...
Recensione Xiaomi Pad 8 Pro: potenza bruta e HyperOS 3 per sfidare la fascia alta Recensione Xiaomi Pad 8 Pro: potenza bruta e Hyp...
NZXT H9 Flow RGB+, Kraken Elite 420 e F140X: abbiamo provato il tris d'assi di NZXT NZXT H9 Flow RGB+, Kraken Elite 420 e F140X: abb...
La NASA ha confermato il supporto per il...
Sierra Space ha completato il test acust...
Ryzen 7 5800X3D pronto a tornare sul mer...
NASA: l'amministrazione Trump prosegue s...
L'Iran avrebbe acquistato un satellite p...
VivaTech compie dieci anni e raddoppia p...
Le vendite di CPU si sono ridotte di 25 ...
Starship: SpaceX ha completato lo static...
Huawei FusionSolar Roadshow 2026: l'inno...
Nuovo trailer per Street Fighter: un fil...
Sovranità sui dati: arriva la pri...
Schede video NVIDIA e AMD di nuovo su Ma...
Robot aspirapolvere, TV OLED, iPhone 17 ...
EUREKA J15 Pro Ultra super interessante ...
Intel porta l'AI nei notebook entry-leve...
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: 23:36.


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