Torna indietro   Hardware Upgrade Forum > Software > Programmazione

Recensione OPPO Find X9 Ultra: è lui il cameraphone definitivo
Recensione OPPO Find X9 Ultra: è lui il cameraphone definitivo
Find X9 Ultra è lo smartphone che tanti aspettavano, e finalmente è arrivato anche in Italia. Abbiamo provato il flagship di OPPO per diverse settimane, e siamo volati fino in Cina alla sua presentazione ufficiale. Tutto gira intorno al suo incredibile comparto fotografico in collaborazione con Hasselblad e con un totale di sei fotocamere. Il resto è un mix di specifiche di altissimo livello, così come il prezzo. Vi raccontiamo tutto nella nostra recensione completa.
Ecovacs Deebot X12 OmniCyclone: lava grazie a FocusJet
Ecovacs Deebot X12 OmniCyclone: lava grazie a FocusJet
Il nuovo Deebot X12 OmniCyclone abbina un sistema di raccolta dello sporco senza sacchetto, un rullo di lavaggio esteso e la tecnologia FocusJet per intervenire più efficacemente sulle macchie più persistenti. Un robot completo e preciso che aiuta a tenere puliti i pavimenti di casa con il minimo sforzo
Narwal Flow 2: la pulizia di casa con un mocio a nastro
Narwal Flow 2: la pulizia di casa con un mocio a nastro
Narwal Flow 2 implementa un mocio a nastro che esegue una pulizia dettagliata del pavimento di casa, in abbinamento ad un potente motore di aspirazione della polvere: un prodotto ideale per gestire in autonomia e con grande efficacia le necessità di pulizia dei pavimenti di casa
Tutti gli articoli Tutte le news

Vai al Forum
Rispondi
 
Strumenti
Old 03-06-2013, 12:07   #1
metiu0003
Junior Member
 
Iscritto dal: Jun 2013
Messaggi: 8
intersezione elementi array

Buongiorno a tutti,
avrei questo esercizio da risolvere: Dati due vettori A e B (lunghi n ed m, rispettivamente) che rispettano il vincolo 1 e con distanza massima fra numeri comuni pari a k (costante), determinare in modo efficiente tutti e soli i numeri presenti contemporaneamente in A e B, nello stesso ordine in cui compaiono,
utilizzando al massimo O(k) (cioè O(1)) spazio aggiuntivo rispetto allo spazio per l’input.

Il vincolo 1 è : per ogni posizione i e j nel vettore A e per ogni posizione i' e j' nel vettore B: se A[i] = B[i'] ∧ A[j] = B[j'] ∧ i < j allora i'< j'. Cioè in altre parole i numeri in comune compaiono nello stesso ordine nei due vettori e la distanza tra due numeri comuni consecutivi in un vettore è <= a k.

Ad esempio:
A= 3 7 5 9 10 15 16 1 6 2
B= 4 8 5 13 1 17 2 11
quindi m = 10, n = 8, k = 6
il risultato è 5 1 2

Ultima modifica di metiu0003 : 03-06-2013 alle 13:32. Motivo: errore di scrittura
metiu0003 è offline   Rispondi citando il messaggio o parte di esso
Old 03-06-2013, 12:56   #2
wingman87
Senior Member
 
Iscritto dal: Nov 2005
Messaggi: 2789
L'esercizio è carino ma l'esempio è sbagliato...
Comunque dov'è che ti incarti?
wingman87 è offline   Rispondi citando il messaggio o parte di esso
Old 03-06-2013, 13:10   #3
metiu0003
Junior Member
 
Iscritto dal: Jun 2013
Messaggi: 8
si scusa l'esempio giusto è:
A= 3 7 5 9 10 15 16 1 6 5
B= 4 8 5 13 1 17 2 11
quindi m = 10, n = 8, k = 6
il risultato è 5 1 2


Io pensavo di partire cercando il primo elemento comune ad entrambi i vettori e poi confrontare i successivi k elementi di entrambi i vettori per trovare l'eventuale elemento comune successivo. Però credo che sicuramente ci sia una soluzione migliore della mia, magari qualcosa che non sfrutta l'ordinamento.
metiu0003 è offline   Rispondi citando il messaggio o parte di esso
Old 03-06-2013, 13:23   #4
wingman87
Senior Member
 
Iscritto dal: Nov 2005
Messaggi: 2789
Secondo me devi sfruttare sin dal principio la distanza k, quindi anche nella ricerca della prima occorrenza. Inoltre l'esercizio ti permette di utilizzare O(k) spazio aggiuntivo e questo potrebbe permetterti di adottare un algoritmo più rapido.
Comunque l'esempio è ancora sbagliato (in A non è presente 2)
wingman87 è offline   Rispondi citando il messaggio o parte di esso
Old 03-06-2013, 13:36   #5
metiu0003
Junior Member
 
Iscritto dal: Jun 2013
Messaggi: 8
Adesso dovrebbe essere giusto.
Comunque avevo pensato anch'io di fare circa cosi però non mi viene in mente come fare. Riusciresti a farmi un esempio, qualcosa tipo pseudocodice magari.
metiu0003 è offline   Rispondi citando il messaggio o parte di esso
Old 03-06-2013, 15:57   #6
wingman87
Senior Member
 
Iscritto dal: Nov 2005
Messaggi: 2789
Quali strutture dati conosci?
wingman87 è offline   Rispondi citando il messaggio o parte di esso
Old 03-06-2013, 17:30   #7
metiu0003
Junior Member
 
Iscritto dal: Jun 2013
Messaggi: 8
Vanno bene tutte: liste, heap, code, stack, alberi bst o red black ma possibilmente non tabelle hash.
metiu0003 è offline   Rispondi citando il messaggio o parte di esso
Old 04-06-2013, 08:37   #8
wingman87
Senior Member
 
Iscritto dal: Nov 2005
Messaggi: 2789
Ci ho pensato un po' ma c'è una questione che non mi torna... Per come è posto il problema i primi due numeri in comune potrebbero trovarsi in qualunque posizione in A e in B, ad esempio alla posizione 1 in A e alla posizione 100 in B. C'è qualche considerazione aggiuntiva in merito?
Inoltre una soluzione banale ma che credo non sia concessa è ordinare uno dei due array e poi scorrere l'altro cercando i vari numeri nel primo (ricerca dicotomica). Non credo sia concessa perché uno degli input viene irrimediabilmente modificato...
wingman87 è offline   Rispondi citando il messaggio o parte di esso
Old 04-06-2013, 09:42   #9
metiu0003
Junior Member
 
Iscritto dal: Jun 2013
Messaggi: 8
Infatti il problema è la posizione del primo numero in comune. Oltre a quello che ti ho detto non c'è nient'altro altro. La soluzione banale non usa k quindi non va bene.
metiu0003 è offline   Rispondi citando il messaggio o parte di esso
Old 06-06-2013, 17:36   #10
metiu0003
Junior Member
 
Iscritto dal: Jun 2013
Messaggi: 8
Il primo elemento in comune si trova in posizione 0,k-1.
metiu0003 è offline   Rispondi citando il messaggio o parte di esso
Old 06-06-2013, 17:37   #11
metiu0003
Junior Member
 
Iscritto dal: Jun 2013
Messaggi: 8
Quote:
Originariamente inviato da wingman87 Guarda i messaggi
Ci ho pensato un po' ma c'è una questione che non mi torna... Per come è posto il problema i primi due numeri in comune potrebbero trovarsi in qualunque posizione in A e in B, ad esempio alla posizione 1 in A e alla posizione 100 in B. C'è qualche considerazione aggiuntiva in merito?
Inoltre una soluzione banale ma che credo non sia concessa è ordinare uno dei due array e poi scorrere l'altro cercando i vari numeri nel primo (ricerca dicotomica). Non credo sia concessa perché uno degli input viene irrimediabilmente modificato...
Il primo elemento si trova in tra la posizione 0 e la k-1.
metiu0003 è offline   Rispondi citando il messaggio o parte di esso
Old 07-06-2013, 19:47   #12
wingman87
Senior Member
 
Iscritto dal: Nov 2005
Messaggi: 2789
Ok, allora quello che puoi fare è sfruttare una struttura dati per metterci fino a k elementi. Questa struttura deve permetterti di cercare un elemento al suo interno con complessità meno che lineare, compreso l'inserimento (altrimenti non c'è guadagno). Inoltre deve restituirti l'indice dell'elemento cercato.
Grazie a questa struttura puoi metterci i primi k elementi di A e poi uno ad uno cercare gli elementi di B nella struttura. Quando trovi una corrispondenza in A all'indice j, svuoti la struttura e ci metti tutti gli elementi da j+1 a j+k e continui.
Questo come base, poi puoi fare delle migliorie...
wingman87 è offline   Rispondi citando il messaggio o parte di esso
 Rispondi


Recensione OPPO Find X9 Ultra: è lui il cameraphone definitivo Recensione OPPO Find X9 Ultra: è lui il c...
Ecovacs Deebot X12 OmniCyclone: lava grazie a FocusJet Ecovacs Deebot X12 OmniCyclone: lava grazie a Fo...
Narwal Flow 2: la pulizia di casa con un mocio a nastro Narwal Flow 2: la pulizia di casa con un mocio a...
Tastiera gaming MSI GK600 TKL: switch hot-swap, display LCD e tre modalità wireless Tastiera gaming MSI GK600 TKL: switch hot-swap, ...
DJI Osmo Pocket 4: la gimbal camera tascabile cresce e ha nuovi controlli fisici DJI Osmo Pocket 4: la gimbal camera tascabile cr...
Stretto di Hormuz, finti funzionari iran...
Dragon Ball Xenoverse 3 annunciato uffic...
WINDTRE BUSINESS potenzia i servizi IoT ...
OPPO rinnova l'ecosistema: arrivano Watc...
OPPO Find X9 Ultra ufficiale: debutta il...
Renault Twingo: esposta a Milano per far...
Intel vuole cambiare: overclocking anche...
Anche PlayStation introduce la verifica ...
Samsung ed Sk hynix, i bonus per gli ope...
Windows 11 velocizza Esplora File: ecco ...
Funzioni nascoste nelle librerie ADLX Ra...
Itala rinasce: lo storico marchio automo...
Huawei Watch Fit 5 e 5 Pro ufficiali: di...
ECOVACS DEEBOT T90 PRO OMNI vs Roborock ...
Fastweb scompare dai partner Starlink Mo...
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: 14:27.


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