Torna indietro   Hardware Upgrade Forum > Software > Programmazione

WoW: Midnight, Blizzard mette il primo, storico mattone per l'housing e molto altro
WoW: Midnight, Blizzard mette il primo, storico mattone per l'housing e molto altro
Con Midnight, Blizzard tenta il colpaccio: il player housing sbarca finalmente su Azeroth insieme a una Quel'Thalas ricostruita da zero. Tra il dramma della famiglia Ventolesto e il nuovo Prey System, ecco com'è la nuova espansione di World of Warcraft
Ecovacs Goat O1200 LiDAR Pro: la prova del robot tagliaerba con tagliabordi integrato
Ecovacs Goat O1200 LiDAR Pro: la prova del robot tagliaerba con tagliabordi integrato
Nuova frontiera per i robot tagliaerba, con Ecovacs GOAT O1200 LiDAR Pro che riconosce l'ambiente in maniera perfetta, grazie a due sensori LiDAR, e dopo la falciatura può anche rifinire il bordo con il tagliabordi a filo integrato
Recensione Samsung Galaxy S26+: sfida l'Ultra, ma ha senso di esistere?
Recensione Samsung Galaxy S26+: sfida l'Ultra, ma ha senso di esistere?
Equilibrio e potenza definiscono il Samsung Galaxy S26+, un flagship che sfida la variante Ultra e la fascia alta del mercato con il primo processore mobile a 2nm. Pur mantenendo l'hardware fotografico precedente, lo smartphone brilla per un display QHD+ da 6,7 pollici d'eccellenza, privo però del trattamento antiriflesso dell'Ultra, e per prestazioni molto elevate. Completano il quadro la ricarica wireless a 20W e, soprattutto, un supporto software settennale
Tutti gli articoli Tutte le news

Vai al Forum
Rispondi
 
Strumenti
Old 09-03-2004, 17:49   #1
Strat
Member
 
L'Avatar di Strat
 
Iscritto dal: Oct 2003
Messaggi: 126
[Java] Random

Qualcuno sa dirmi se la funzione che spara numeri random in java e lenta, cioè nextInt?

Spiegandomi meglio: ho realizzato un ordinamento QuickSort in due modi, uno deterministico con pivot il primo elemento e uno randomizzato con una scelta casuale del pivot fra gli elementi inseriti nell'array.
Però, diversamente dalle previsioni, è più veloce la versione deterministica.
Essendo le due realizzate in modo identico apparte per la scelta del pivot, viene spontaneo pensare, almeno e me, che il problema stia nella randomizzaione.
Può essere?

Un'altra ipotesi è quella che io abbia scritto una formula di "restringimento" al range che mi interessa che fa schifo.
eccola:

int choise = from + (generator.nextInt((to-from)));

mi da un valore tra from e to.

Grazie tante, è importante!!!

Ciao!
Strat è offline   Rispondi citando il messaggio o parte di esso
Old 09-03-2004, 19:44   #2
PGI
Bannato
 
L'Avatar di PGI
 
Iscritto dal: Nov 2001
Città: Verona
Messaggi: 1086
Non ho mai cronometrato la faccenda, ma potresti provare con un'interfaccia JNI a interrogare un generatore di interi Random scritto in codice nativo.

A dire il vero il "ponte" JNI non è che sia il pezzo più efficiente di Java, però se il codice nativo è sensibilmente più rapido di quello della classe Math potresti averne dei benefici.
PGI è offline   Rispondi citando il messaggio o parte di esso
Old 10-03-2004, 09:54   #3
Angus
Senior Member
 
L'Avatar di Angus
 
Iscritto dal: Dec 2001
Città: Milano
Messaggi: 545
non per cercare il pelo nell'uovo...

...ma i test di confronto tra le due realizzazioni li fai con un ampia scelta di input iniziali, magari di dimensioni piuttosto generose? Il quicksort randomizzato dovrebbe essere statisticamente più veloce, non sempre più veloce.
__________________
Angus the Hunter @ Realm of magic | Angus Young @ Batracer
°SetiEmperor°| Ninja Technologies
{ qualunque cosa sia, è veloce e fa male (cit.) }
Angus è offline   Rispondi citando il messaggio o parte di esso
Old 10-03-2004, 10:07   #4
Angus
Senior Member
 
L'Avatar di Angus
 
Iscritto dal: Dec 2001
Città: Milano
Messaggi: 545
vorrei anche aggiungere che...

... il costo dell'istruzione nextInt() è costante, e moltiplica il costo complessivo dell'algoritmo, che nel caso medio , per la versione randomizzata e per quella non randomizzata, è comunque O(n * log(n)), per una costante K. Quindi per input sufficientemente grandi dovresti osservare, statisticamente, che la versione randomizzata è più veloce.
__________________
Angus the Hunter @ Realm of magic | Angus Young @ Batracer
°SetiEmperor°| Ninja Technologies
{ qualunque cosa sia, è veloce e fa male (cit.) }
Angus è offline   Rispondi citando il messaggio o parte di esso
Old 10-03-2004, 10:14   #5
Angus
Senior Member
 
L'Avatar di Angus
 
Iscritto dal: Dec 2001
Città: Milano
Messaggi: 545
per giudicare la bontà della tua implementazione...

... prova a confrontarne le prestazioni col metodo public static void sort(int[] a) della classe java.util.Arrays di cui cito testualmente la definizione:

"Sorts the specified array of ints into ascending numerical order. The sorting algorithm is a tuned quicksort, adapted from Jon L. Bentley and M. Douglas McIlroy's "Engineering a Sort Function", Software-Practice and Experience, Vol. 23(11) P. 1249-1265 (November 1993). This algorithm offers n*log(n) performance on many data sets that cause other quicksorts to degrade to quadratic performance."
__________________
Angus the Hunter @ Realm of magic | Angus Young @ Batracer
°SetiEmperor°| Ninja Technologies
{ qualunque cosa sia, è veloce e fa male (cit.) }
Angus è offline   Rispondi citando il messaggio o parte di esso
Old 10-03-2004, 19:52   #6
Strat
Member
 
L'Avatar di Strat
 
Iscritto dal: Oct 2003
Messaggi: 126
Grazie comunque avevo risolto.

Naturalmete inserisco molti elementi nella sequenza da ordinare, fino a 3000000, con un range di elementi da 0 a 10000000.

E' una sequenza talmente disordinata che i casi cosiddetti cattivi sono rari per tutte le versioni, deterministiche e non.

Comunque la funzione nextInt anche se di un valore trascurabile un po' rallenta, e pur sempre un qualcosa in più in confronto alla versine di Quick Sort che non c'e l'ha.

Ciao e grazie!
Strat è offline   Rispondi citando il messaggio o parte di esso
Old 11-03-2004, 14:53   #7
cn73
Senior Member
 
L'Avatar di cn73
 
Iscritto dal: Jul 1999
Città: Torino
Messaggi: 2221
Ti ricordi di inizializzare ogni volta il generatore di numeri casuali vero? E' un errore frequente...
cn73 è offline   Rispondi citando il messaggio o parte di esso
 Rispondi


WoW: Midnight, Blizzard mette il primo, storico mattone per l'housing e molto altro WoW: Midnight, Blizzard mette il primo, storico ...
Ecovacs Goat O1200 LiDAR Pro: la prova del robot tagliaerba con tagliabordi integrato Ecovacs Goat O1200 LiDAR Pro: la prova del robot...
Recensione Samsung Galaxy S26+: sfida l'Ultra, ma ha senso di esistere? Recensione Samsung Galaxy S26+: sfida l'Ultra, m...
Zeekr X e 7X provate: prezzi, autonomia fino a 615 km e ricarica in 13 minuti Zeekr X e 7X provate: prezzi, autonomia fino a 6...
Marathon: arriva il Fortnite hardcore Marathon: arriva il Fortnite hardcore
OnePlus Nord 6 ufficiale: arriva con una...
Google lancia di nascosto un'app AI che ...
Sony lancia The Playerbase per inserire ...
WhatsApp si aggiorna con una nuova app c...
Windows 11 23H2, ricerca nel menu Start ...
Google Chrome introduce il layout vertic...
Artemis II: per la prima volta degli ast...
Battery swap e flotte smart: così nasce ...
Apple affronta un dilemma con il MacBook...
ECOVACS X11 OMNICYCLONE: 19.500 Pa, moci...
ll nuovo HONOR 600 Lite 5G arriva in Ita...
Kindle, addio allo store sui vecchi e-re...
DJI Flip Combo Fly More a 599€ invece di...
Addio cavi e adattatori multipli: Techly...
MOVA M50 Ultra: scopa elettrica con brac...
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: 11:44.


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