Torna indietro   Hardware Upgrade Forum > Software > Programmazione

Recensione vivo X300 Pro: è ancora lui il re della fotografia mobile, peccato per la batteria
Recensione vivo X300 Pro: è ancora lui il re della fotografia mobile, peccato per la batteria
vivo X300 Pro rappresenta un'evoluzione misurata della serie fotografica del produttore cinese, con un sistema di fotocamere migliorato, chipset Dimensity 9500 di ultima generazione e l'arrivo dell'interfaccia OriginOS 6 anche sui modelli internazionali. La scelta di limitare la batteria a 5.440mAh nel mercato europeo, rispetto ai 6.510mAh disponibili altrove, fa storcere un po' il naso
Lenovo Legion Go 2: Ryzen Z2 Extreme e OLED 8,8'' per spingere gli handheld gaming PC al massimo
Lenovo Legion Go 2: Ryzen Z2 Extreme e OLED 8,8'' per spingere gli handheld gaming PC al massimo
Lenovo Legion Go 2 è la nuova handheld PC gaming con processore AMD Ryzen Z2 Extreme (8 core Zen 5/5c, GPU RDNA 3.5 16 CU) e schermo OLED 8,8" 1920x1200 144Hz. È dotata anche di controller rimovibili TrueStrike con joystick Hall effect e una batteria da 74Wh. Rispetto al dispositivo che l'ha preceduta, migliora ergonomia e prestazioni a basse risoluzioni, ma pesa 920g e costa 1.299€ nella configurazione con 32GB RAM/1TB SSD e Z2 Extreme
AWS re:Invent 2025: inizia l'era dell'AI-as-a-Service con al centro gli agenti
AWS re:Invent 2025: inizia l'era dell'AI-as-a-Service con al centro gli agenti
A re:Invent 2025, AWS mostra un’evoluzione profonda della propria strategia: l’IA diventa una piattaforma di servizi sempre più pronta all’uso, con agenti e modelli preconfigurati che accelerano lo sviluppo, mentre il cloud resta la base imprescindibile per governare dati, complessità e lock-in in uno scenario sempre più orientato all’hybrid cloud
Tutti gli articoli Tutte le news

Vai al Forum
Rispondi
 
Strumenti
Old 30-01-2014, 22:04   #1
arsenico2009
Member
 
Iscritto dal: Sep 2010
Messaggi: 153
migliore algoritmo C++ per verificare se in una sequenza di numeri tutti sono diversi

qual'è il migliore algoritmo per C++ per verificare se in una sequenza di numeri tutti sono diversi ??

qual'è il vostro modo di procedere tenendo conto che io ho un array di N numeri.
arsenico2009 è offline   Rispondi citando il messaggio o parte di esso
Old 30-01-2014, 22:23   #2
arsenico2009
Member
 
Iscritto dal: Sep 2010
Messaggi: 153
posta il codice
arsenico2009 è offline   Rispondi citando il messaggio o parte di esso
Old 30-01-2014, 22:27   #3
arsenico2009
Member
 
Iscritto dal: Sep 2010
Messaggi: 153
io ho pensato questo:

poniamo che il prog deve generare N numeri casuali diversi.

for (int i=0; i<N; i++){
ripeti:
numeri[i]=generaNumeri();
for (int j=i-1; j>=0; j--){
if (numeri[i] == numeri[j]){
goto ripeti;
}
}
}
arsenico2009 è offline   Rispondi citando il messaggio o parte di esso
Old 30-01-2014, 22:30   #4
arsenico2009
Member
 
Iscritto dal: Sep 2010
Messaggi: 153
il problema è che con questo algoritmo per un numero elevato di numeri ci mette troppo tempo.

io invece volevo un algoritmo più efficiente.

in pratica devo generare N numeri diversi, con N anche 1 milione.
arsenico2009 è offline   Rispondi citando il messaggio o parte di esso
Old 30-01-2014, 22:48   #5
wingman87
Senior Member
 
Iscritto dal: Nov 2005
Messaggi: 2782
Li ordini e poi li scorri uno ad uno, se non ne trovi due vicini uguali è perché non ce ne sono. Questo algoritmo è O(nlog(n))
wingman87 è offline   Rispondi citando il messaggio o parte di esso
Old 30-01-2014, 22:58   #6
arsenico2009
Member
 
Iscritto dal: Sep 2010
Messaggi: 153
mi fai vedere come applicarlo. non ho ben capito.

scrivi un pezzo di codice.
arsenico2009 è offline   Rispondi citando il messaggio o parte di esso
Old 30-01-2014, 23:04   #7
wingman87
Senior Member
 
Iscritto dal: Nov 2005
Messaggi: 2782
Però questo risolve il problema iniziale. Se invece vuoi generare N numeri tutti diversi, se possibile, puoi creare una sequenza che va da 1 a N e poi "disordinarla".
Se invece devono essere N numeri completamente random l'affare si complica, probabilmente ti conviene inserire uno ad uno gli elementi random in una struttura ordinata, avendo cura di controllare ogni volta che l'elemento non sia già presente (oppure, meglio, la struttura può non fare nulla se l'elemento da inserire è già presente).
In casi come questo non so come si calcola la complessità perché a livello teorico potrebbe anche non terminare mai se ad un certo step non viene più generato nessun numero non ancora presente nella struttura...
Se possibile adotta il primo metodo, tieni conto del fatto che non devi necessariamente usare i numeri da 1 a N ma puoi anche generarli secondo una qualche distribuzione, basta che siano tutti diversi, e poi disordinarli.
wingman87 è offline   Rispondi citando il messaggio o parte di esso
Old 30-01-2014, 23:04   #8
clockover
Senior Member
 
L'Avatar di clockover
 
Iscritto dal: Oct 2004
Messaggi: 1945
Diciamo che comunque il titolo del post non è pienamente attinente a quello che stai cercando di fare. Tu vuoi creare una sequenza di numeri tutti diversi

Soluzione 1
Ti crei un array da 0 a N (dove N è il numero più grande che vorresti avere nel tuo vettore casuale). Generi un numero random da 0 a N che chiameremo M. Rimuovi dal tuo array l'elemento con indice M (lo rimuovi completamente) e lo inserisci nel tuo vettore che stai generando. L'array iniziale adesso è più piccolo di 1 quindi qualunque altro numero M casuale punterà ad un altro elemento e così via.
Es.
Array[0-N]
Casuale (per ora ha dimensione 0)
genero M (random da 0 a N)
Casuale[0] = Array[M]
rimuovo Array[M]
genero M (random da 0 a N-1)
Casuale[1] = Array[M]
rimuovo Array[M]
.....

Soluzione 2
Ogni numero casuale generato verrà inserito in un Set. Non è un buon metodo comunque.
clockover è offline   Rispondi citando il messaggio o parte di esso
Old 30-01-2014, 23:08   #9
wingman87
Senior Member
 
Iscritto dal: Nov 2005
Messaggi: 2782
Quote:
Originariamente inviato da arsenico2009 Guarda i messaggi
mi fai vedere come applicarlo. non ho ben capito.

scrivi un pezzo di codice.
Te lo scrivo in pseudo codice:

Codice:
checkAllUnique (array, nElem) {
   sortedArray = sort(array)
   previousElem = sortedArray[0];
   for(i=1; i<nElem; i++){
      if(sortedArray[i] == previousElem)
         return false;
      previousElem = sortedArray[i];
   }
   return true;
}
wingman87 è offline   Rispondi citando il messaggio o parte di esso
Old 30-01-2014, 23:23   #10
arsenico2009
Member
 
Iscritto dal: Sep 2010
Messaggi: 153
in metodo di CLOCK_OVER è più efficiente.

il problema è che come si elimina un elemento da un'array ?
arsenico2009 è offline   Rispondi citando il messaggio o parte di esso
Old 31-01-2014, 05:16   #11
clockover
Senior Member
 
L'Avatar di clockover
 
Iscritto dal: Oct 2004
Messaggi: 1945
Quote:
Originariamente inviato da arsenico2009 Guarda i messaggi
in metodo di CLOCK_OVER è più efficiente.

il problema è che come si elimina un elemento da un'array ?
Si ma l'efficienza di un metodo "in pratica" dipende dall'utilizzo che se ne deve fare. Cosa devi farci con questi numeri casuali?
Per quanto riguarda rimuovere un elemento da un array in C++ non posso aiutarti

Inviato da una supercazzola ed un Nexus 5 scappellato a sinistra.. con senso unico
clockover è offline   Rispondi citando il messaggio o parte di esso
Old 31-01-2014, 09:28   #12
Daniels118
Senior Member
 
L'Avatar di Daniels118
 
Iscritto dal: Jan 2014
Messaggi: 852
Puoi usare un generatore di numeri casuali con un periodo maggiore del numero di elementi nell'array.

Oppure ogni volta che inserisci un elemento gli assegni il valore usato in precedenza incrementato di una quantità casuale (*non troppo grande*), alla fine fai degli scambi casuali sugli elementi per disordinarli.
Volendo l'algoritmo si può anche migliorare per evitare di dover fare gli scambi casuali.
Daniels118 è offline   Rispondi citando il messaggio o parte di esso
Old 31-01-2014, 11:31   #13
clockover
Senior Member
 
L'Avatar di clockover
 
Iscritto dal: Oct 2004
Messaggi: 1945
Quote:
Originariamente inviato da coffe_killer Guarda i messaggi
Comunque per il discorso efficienza, onestamente per un algoritmo del genere non starei troppo a guardare una cosa del genere...la generazione di un numero per una CPU è poca roba, anche se ben fossero 1000000, chissenefrega...cioè è giusto calcolare complessità e complessità, ma di solito sono cose irrilevanti per frammenti di codice così piccoli...si comincia a ragionare in quei termini solo se cominci ad avere un programma con migliaia di righe di codice annidate e ricorsioni a manetta...

mi è capitato spesso di sviluppare, sia in uni, sia sul lavoro, programmi corposi, sia in C sia in Java, ma non ho mai davvero apprezzato cambiamenti significativi tra un algoritmo e l'altro...è un discorso che vale di più per la creazione di SO, sistemi distribuiti, algoritmi di calcolo scientifico ecc....
Non mi ci trovo tanto nel tuo ragionamento. Quindi mi stai dicendo che se io volessi generare 50 numeri, tutti totalmente diversi e su una base di 70 numeri, chissenefrega....vai di forza bruta? Tanto che ci mette a generare un numero?
clockover è offline   Rispondi citando il messaggio o parte di esso
Old 31-01-2014, 11:38   #14
Daniels118
Senior Member
 
L'Avatar di Daniels118
 
Iscritto dal: Jan 2014
Messaggi: 852
Un milione di numeri non sono pochi, per verificare se ci sono duplicati con l'algoritmo semplice (due cicli annidati che confrontano ogni elemento con tutti gli altri), la complessità o(n^2) implica 1000000^2 = mille miliardi di operazioni!
E se capita un doppione bisogna sostituirlo con un altro numero casuale fino a quando non diventa unico!

La soluzione che ho proposto prima consente di generare direttamente numeri unici, casuali e distribuiti in modo uniforme.
Daniels118 è offline   Rispondi citando il messaggio o parte di esso
Old 31-01-2014, 11:44   #15
clockover
Senior Member
 
L'Avatar di clockover
 
Iscritto dal: Oct 2004
Messaggi: 1945
Quote:
Originariamente inviato da Daniels118 Guarda i messaggi
Un milione di numeri non sono pochi, per verificare se ci sono duplicati con l'algoritmo semplice (due cicli annidati che confrontano ogni elemento con tutti gli altri), la complessità o(n^2) implica 1000000^2 = mille miliardi di operazioni!
E se capita un doppione bisogna sostituirlo con un altro numero casuale fino a quando non diventa unico!

La soluzione che ho proposto prima consente di generare direttamente numeri unici, casuali e distribuiti in modo uniforme.
Ma se hai un numero limitato di numeri? Supponiamo che il massimo numero che puoi inserire è 90 e devi sceglierne casualmente 10, e a prima botta ti esce 89...
clockover è offline   Rispondi citando il messaggio o parte di esso
Old 31-01-2014, 12:04   #16
!fazz
Moderatore
 
L'Avatar di !fazz
 
Iscritto dal: Nov 2006
Messaggi: 21919
l'algoritmo semplice di ricerca iterativa (quello con due cicli ) va benissimo se il numero di elementi è limitato, se diventano parecchi (milioni o più) forse è meglio pensare ad alcuni trucchetti per ridurre il tempo di esecuzione come ad esempio, il primo che mi viene in mente usare una hash table e verificare se ci sono doppioni solamente nelle collisioni
__________________
"WS" (p280,cx750m,4790k+212evo,z97pro,4x8GB ddr3 1600c11,GTX760-DC2OC,MZ-7TE500, WD20EFRX)
Desktop (three hundred,650gq,3800x+nh-u14s ,x570 arous elite,2x16GB ddr4 3200c16, rx5600xt pulse P5 1TB)+NB: Lenovo p53 i7-9750H,64GB DDR4,2x1TB SSD, T1000
!fazz è offline   Rispondi citando il messaggio o parte di esso
Old 31-01-2014, 12:21   #17
Daniels118
Senior Member
 
L'Avatar di Daniels118
 
Iscritto dal: Jan 2014
Messaggi: 852
Mi autoquoto:
Quote:
(*non troppo grande*)
Cerco di non dilungarmi troppo nelle risposte per evitare di dire cose scontate, comunque, visto che sembra che non lo siano così tanto, ecco gli accorgimenti da adottare:
1) anche il primo numero generato deve essere *non troppo grande*;
2) per *non troppo grande* si intende compreso tra zero (EDIT: strettamente maggiore di zero) e MAX/N, dove MAX è il valore massimo accettabile nell'intero vettore ed N è il numero di elementi da inserire.

Nel peggiore dei casi (tutti gli incrementi casuali uguali a MAX/N: e che sfiga!),
avremo che il kappesimo numero sarà uguale a:
SOMMATORIA per i da 1 a K DI (MAX/N) = k*(MAX/N)
l'ennesimo numero sarà quindi N*(MAX/N), che è la stessa cosa di MAX*(N/N),
poiché N/N = 1, il massimo sarà uguale a MAX.

In molti linguaggi la funzione random accetta direttamente il valore massimo da generare, altrimenti è possibile ovviare utilizzando l'operatore modulo (la percentuale in C).

Ultima modifica di Daniels118 : 31-01-2014 alle 12:24.
Daniels118 è offline   Rispondi citando il messaggio o parte di esso
Old 31-01-2014, 12:44   #18
-MiStO-
Senior Member
 
Iscritto dal: May 2005
Città: Trieste
Messaggi: 2285
Quote:
Originariamente inviato da !fazz Guarda i messaggi
l'algoritmo semplice di ricerca iterativa (quello con due cicli ) va benissimo se il numero di elementi è limitato, se diventano parecchi (milioni o più) forse è meglio pensare ad alcuni trucchetti per ridurre il tempo di esecuzione come ad esempio, il primo che mi viene in mente usare una hash table e verificare se ci sono doppioni solamente nelle collisioni
esattamente:hastable e via per controllare se il numero e gia stato generato / trovato
__________________
neo mini v2 / asus strix z490i / 10600k@? / uh12s / rx6700xt / 32gb ddr4@3200 / sandisk 250 + asenno 1tb / lenovo g34w
trattative concluse : tante...

-MiStO- è offline   Rispondi citando il messaggio o parte di esso
Old 31-01-2014, 13:02   #19
Daniels118
Senior Member
 
L'Avatar di Daniels118
 
Iscritto dal: Jan 2014
Messaggi: 852
L'hashtable è una buona soluzione, però così si spreca parecchia memoria per conservare dei cloni dei numeri generati.
Però questo problema non è rilevante se la memoria a disposizione è abbondante, il vero problema è che se la quantità di valori si avvicina al valore massimo, c'è un'altissima probabilità di generare duplicati e le prestazioni dell'algoritmo degradano vertiginosamente. Generare direttamente numeri unici garantisce delle performance superiori.
Daniels118 è offline   Rispondi citando il messaggio o parte di esso
Old 01-02-2014, 16:11   #20
arsenico2009
Member
 
Iscritto dal: Sep 2010
Messaggi: 153
in pratica devo creare un programma che genera N (scelto dall'utente) numeri casuali diversi.

l'algoritmo deve essere efficiente perchè se l'utente gli dice generami 2.000.000 di numeri diversi il prog non deve stare due minuti ad elaborare.

deve immediatamente generarli e salvarli in un file.

qual'è il metodo che usereste.

spiegate in modo semplice e con parole non troppo eloquenti.
arsenico2009 è offline   Rispondi citando il messaggio o parte di esso
 Rispondi


Recensione vivo X300 Pro: è ancora lui il re della fotografia mobile, peccato per la batteria Recensione vivo X300 Pro: è ancora lui il...
Lenovo Legion Go 2: Ryzen Z2 Extreme e OLED 8,8'' per spingere gli handheld gaming PC al massimo Lenovo Legion Go 2: Ryzen Z2 Extreme e OLED 8,8'...
AWS re:Invent 2025: inizia l'era dell'AI-as-a-Service con al centro gli agenti AWS re:Invent 2025: inizia l'era dell'AI-as-a-Se...
Cos'è la bolla dell'IA e perché se ne parla Cos'è la bolla dell'IA e perché se...
BOOX Palma 2 Pro in prova: l'e-reader diventa a colori, e davvero tascabile BOOX Palma 2 Pro in prova: l'e-reader diventa a ...
La capsula SpaceX Dragon CRS-33 ha acces...
La NASA è sempre più vicin...
Crisi delle memorie: ASUS torna al passa...
Le console next-generation potrebbero es...
Gemini cresce ancora: la quota di mercat...
Samsung sfida TSMC: la capacità produtti...
Iliad alza il prezzo della fibra ottica ...
Il prossimo low cost di POCO sarà il più...
The Elder Scrolls VI: ecco le ultime sul...
Ecco i saldi di fine anno Amazon, 34 off...
iPhone Fold: scorte limitate al lancio m...
OpenAI porterà la pubblicità in ChatGPT ...
TSMC aumenterà ancora i prezzi: nel 2026...
Marvel pubblica anche il secondo teaser ...
Nuovo accordo tra xAI e il Pentagono: l'...
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:24.


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