Torna indietro   Hardware Upgrade Forum > Software > Programmazione

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
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 615 km e ricarica in 13 minuti
Zeekr sbarca ufficialmente in Italia con tre modelli elettrici premium, X, 7X e 001, distribuiti da Jameel Motors su una rete di 52 punti vendita già attivi. La Zeekr X parte da 39.900 euro, la 7X da 54.100: piattaforma a 800V, chip Snapdragon di ultima generazione, ricarica ultraveloce e un'autonomia dichiarata fino a 615 km WLTP. Le prime consegne sono previste a metà aprile
Tutti gli articoli Tutte le news

Vai al Forum
Rispondi
 
Strumenti
Old 11-07-2006, 09:56   #1
project_34
Member
 
L'Avatar di project_34
 
Iscritto dal: May 2003
Messaggi: 93
[java] Generare numeri non ripetuti

Codice:
Random generatore = new Random();
num = generatore.nextInt(1000);
Devo generare una grande quantità di interi da mettere in un'array (utilizzo il codice riportato sopra), senza che vi siano ripetizioni..qual è il modo meno dispendioso in termini di cpu e cicli? Controllando con un for() per tutti i numeri sarebbe un suicidio..c'è qualche funzione apposta?
__________________
...Time to bring it down again. Don't just call me pessimist. Try and read between the lines...
project_34 è offline   Rispondi citando il messaggio o parte di esso
Old 11-07-2006, 10:18   #2
MEMon
Senior Member
 
Iscritto dal: Dec 2002
Messaggi: 3359
Potresti crearti parallelamente all'array che ti interessa un array temporaneo, dove inserisci gli interi che generi ma in modo ordinato, ognuno al suo indice, poi prima di inserire l'intero nell'array vero controlli se nell'altro array prima o dopo l'intero appena inserito non ce ne sia uno uguale.
Il problema è che se te vuoi un array di 1000 interi, e vuoi che i numeri casuali vadano da 0 a 1000, quando sarai verso la fine che ti mancano pochi interi da inserire ci metterà molto a trovare quello mancante...
Comunque per quello che ho appena detto:
Codice:
for(int i=0;i<size;i++){
    int random=(int)(Math.random()*limite)
    tempArray[random]=random;
    if(tempArray[random]!=tempArray[random-1]&&tempArray[random]!=tempArray[random+1])
           array[i]=random;
}
Non l'ho provato ma dovrebbe funzionare...comunque cerca di lavorare intorno ad una soluzione del genere, cercando di modificare la generazione dei numeri casuali, altrimenti avrai il problema che ti ho detto prima.
MEMon è offline   Rispondi citando il messaggio o parte di esso
Old 11-07-2006, 10:19   #3
MEMon
Senior Member
 
Iscritto dal: Dec 2002
Messaggi: 3359
Ah, l'array temporaneo è meglio che sia un ArrayList così puoi inserire gli elementi senza specificare una dimensione di partenza.
MEMon è offline   Rispondi citando il messaggio o parte di esso
Old 11-07-2006, 10:30   #4
andbin
Senior Member
 
L'Avatar di andbin
 
Iscritto dal: Nov 2005
Città: TO
Messaggi: 5206
Una possibilità potrebbe essere questa:
Codice:
import java.lang.*;
import java.util.Random;

public class UniqueRandom
{
    private Random rnd;
    private int[] values;
    private int size;

    public UniqueRandom (int min, int max, long seed)
    {
        init (min, max);
        rnd = new Random (seed);
    }

    public UniqueRandom (int min, int max)
    {
        init (min, max);
        rnd = new Random ();
    }

    private void init (int min, int max)
    {
        if (min > max)
            throw new IllegalArgumentException ();

        size = max - min + 1;
        values = new int[size];

        for (int i = 0; i < size; i++)
            values[i] = min + i;
    }

    public boolean hasValue ()
    {
        return size > 0;
    }

    public int extract ()
    {
        if (size == 0)
            throw new IllegalStateException ();

        int idx = rnd.nextInt (size);
        int v = values[idx];

        values[idx] = values[--size];

        return v;
    }
}
Nota ... l'ho buttato giù velocemente (comunque funziona, l'ho provato!) ... è la prima cosa che mi è venuta in mente.

Non so se è quello che volevi e se ti va bene.
__________________
Andrea, SCJP 5 (91%) - SCWCD 5 (94%)
andbin è offline   Rispondi citando il messaggio o parte di esso
Old 11-07-2006, 10:59   #5
project_34
Member
 
L'Avatar di project_34
 
Iscritto dal: May 2003
Messaggi: 93
juuuuu ho risolto grazie ad entrambi la tua soluzione andbin è ottima per quello che mi serve
__________________
...Time to bring it down again. Don't just call me pessimist. Try and read between the lines...
project_34 è offline   Rispondi citando il messaggio o parte di esso
 Rispondi


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
HP Imagine 2026: abbiamo visto HP IQ all’opera, ecco cosa può (e non può) fare HP Imagine 2026: abbiamo visto HP IQ all’opera, ...
Le 10 migliori offerte Amazon di Pasqua:...
Nuove fotografie dagli astronauti di Art...
La toilette della capsula Orion Integrit...
GeForce NOW: ecco tutte le novità in arr...
Il Realme 16 5G debutta sul mercato glob...
HONOR svela tre nuovi tablet: il più int...
Tineco Floor One S9 Master: aspira e pul...
Vivo X300 Ultra, il lancio globale è ini...
Offerte robot aspirapolvere Amazon: ECOV...
L'AI genera codice in 8 minuti e i senio...
Ring Intercom Audio a 44,99€ su Amazon: ...
Apple iPhone 16 crolla a 689€: ecco perc...
Google Pixel 9 a 449,90€ con caricatore ...
Ecco la top 7 delle offerte Amazon, aggi...
Ex ingegnere ammette il sabotaggio: migl...
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: 03:49.


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