Torna indietro   Hardware Upgrade Forum > Software > Programmazione

Sony Alpha 7 V, anteprima e novità della nuova 30fps, che tende la mano anche ai creator
Sony Alpha 7 V, anteprima e novità della nuova 30fps, che tende la mano anche ai creator
Dopo oltre 4 anni si rinnova la serie Sony Alpha 7 con la quinta generazione, che porta in dote veramente tante novità a partire dai 30fps e dal nuovo sensore partially stacked da 33Mpixel. L'abbiamo provata per un breve periodo, ecco come è andata dopo averla messa alle strette.
realme GT 8 Pro Dream Edition: prestazioni da flagship e anima racing da F1
realme GT 8 Pro Dream Edition: prestazioni da flagship e anima racing da F1
realme e Aston Martin Aramco F1 Team si sono (ri)unite dando alla vita un flagship con chip Snapdragon 8 Elite Gen 5 e design esclusivo ispirato alle monoposto di Formula 1. La Dream Edition introduce la nuova colorazione Lime Essence abbinata al tradizionale Aston Martin Racing Green, decorazioni intercambiabili personalizzate e una confezione a tema F1, intorno a uno smartphone dall'ottima dotazione tecnica con batteria da 7000mAh ricaricabile a 120W e isola fotografica intercambiabile
OVHcloud Summit 2025: le novità del cloud europeo tra sovranità, IA e quantum
OVHcloud Summit 2025: le novità del cloud europeo tra sovranità, IA e quantum
Abbiamo partecipato all'OVHcloud Summit 2025, conferenza annuale in cui l'azienda francese presenta le sue ultime novità. Abbiamo parlato di cloud pubblico e privato, d'intelligenza artificiale, di computer quantistici e di sovranità. Che forse, però, dovremmo chiamare solo "sicurezza"
Tutti gli articoli Tutte le news

Vai al Forum
Rispondi
 
Strumenti
Old 01-03-2008, 15:51   #1
Skarafaz
Senior Member
 
L'Avatar di Skarafaz
 
Iscritto dal: May 2006
Città: Rovigo
Messaggi: 442
[JAVA] Dizionario Ordinato con albero red-black

Salve raga! Ho un problemone:

devo realizzare un dizionario ordinato con un albero red-black e non riesco ad implementare due metodi (il resto è a posto per fortuna ):

successors(k): restituisce un iteratore delle entry del dizionario con chiave maggiore o uguale a k (in ordine non decrescente)


predecessors(k): restituisce un iteratore delle entry del dizionario con chiave minore o uguale a k (in ordine non decrescente)

Io ho pensato a questo algoritmo:
- visito inorder i nodi dell'albero e inserisco le entry dei nodi interni (i nodi esterni sono vuoti) in una lista L (che quindi sarà ordinata in ordine non decrescente);
- scandisco le entry contenute in L e metto quelle con chiave maggiore o uguale a k in un'altra lista S;
- da S ricavo l'iteratore.

l'algoritmo funziona! Però non sfrutta le proprietà degli alberi binari di ricerca ed è inutilmente costoso!!!


qualcuno può suggerirmi qualcosa di meglio?

grazie.
Skarafaz è offline   Rispondi citando il messaggio o parte di esso
Old 02-03-2008, 13:23   #2
Skarafaz
Senior Member
 
L'Avatar di Skarafaz
 
Iscritto dal: May 2006
Città: Rovigo
Messaggi: 442
up
Skarafaz è offline   Rispondi citando il messaggio o parte di esso
Old 02-03-2008, 14:00   #3
gugoXX
Senior Member
 
L'Avatar di gugoXX
 
Iscritto dal: May 2004
Città: Londra (Torino)
Messaggi: 3692
La specifica: "In ordine non decrescente" significa che li vuoi in "ordine crescente" oppure in "ordine qualsiasi, purche' soddisfino il filtro"?
Se l'ordine e' qualsiasi, allora dovrebbe essere sufficiente quanto segue, altrimenti occorre cambiarlo un po', ma si dovrebbe poter fare a paritre da questo:

Quote:
Originariamente inviato da Skarafaz Guarda i messaggi
successors(k): restituisce un iteratore delle entry del dizionario con chiave maggiore o uguale a k (in ordine non decrescente)
Cerco in il nodo Nk, con ricerca binaria
Dovrebbe essere sufficiente un iteratore su tutti i nodi che sono figli di destra di Nk

Quote:
predecessors(k): restituisce un iteratore delle entry del dizionario con chiave minore o uguale a k (in ordine non decrescente)
Cerco in il nodo Nk, con ricerca binaria.
Lo cerco con una visita in profondita', prendendo sempre la strada di sinistra.
Restituisco tutti i valori, fino a che non trovo il primo > di k. Termino senza restituirlo.
__________________
Se pensi che il tuo codice sia troppo complesso da capire senza commenti, e' segno che molto probabilmente il tuo codice e' semplicemente mal scritto.
E se pensi di avere bisogno di un nuovo commento, significa che ti manca almeno un test.

Ultima modifica di gugoXX : 02-03-2008 alle 14:02.
gugoXX è offline   Rispondi citando il messaggio o parte di esso
Old 02-03-2008, 14:07   #4
Skarafaz
Senior Member
 
L'Avatar di Skarafaz
 
Iscritto dal: May 2006
Città: Rovigo
Messaggi: 442
Parlo di ordine "non decrescente" perchè nel dizionario potrebbero esserci delle entry con chiave uguale, per cui parlare di ordine "crescente" non è propriamente corretto! Comunque in soldoni si può tranquillamente parlare di ordine crescente!

Esempio
supponiamo che nel dizionario ci siano entry con queste chiavi intere:
1,5,9,12,12,15,24

successors(9) dovrebbe restituire:12,12,15,24
Skarafaz è offline   Rispondi citando il messaggio o parte di esso
Old 02-03-2008, 14:09   #5
gugoXX
Senior Member
 
L'Avatar di gugoXX
 
Iscritto dal: May 2004
Città: Londra (Torino)
Messaggi: 3692
Quote:
Originariamente inviato da Skarafaz Guarda i messaggi
Parlo di ordine "non decrescente" perchè nel dizionario potrebbero esserci delle entry con chiave uguale, per cui parlare di ordine "crescente" non è propriamente corretto! Comunque in soldoni si può tranquillamente parlare di ordine crescente!

Esempio
supponiamo che nel dizionario ci siano entry con queste chiavi intere:
1,5,9,12,12,15,24

successors(9) dovrebbe restituire:12,12,15,24

Ah ok, allora non basta quello che ho proposto...
Se vuoi la lista ordinata occorre pensarci meglio.
__________________
Se pensi che il tuo codice sia troppo complesso da capire senza commenti, e' segno che molto probabilmente il tuo codice e' semplicemente mal scritto.
E se pensi di avere bisogno di un nuovo commento, significa che ti manca almeno un test.
gugoXX è offline   Rispondi citando il messaggio o parte di esso
Old 04-03-2008, 16:48   #6
Skarafaz
Senior Member
 
L'Avatar di Skarafaz
 
Iscritto dal: May 2006
Città: Rovigo
Messaggi: 442
up
Skarafaz è offline   Rispondi citando il messaggio o parte di esso
Old 04-03-2008, 18:13   #7
gugoXX
Senior Member
 
L'Avatar di gugoXX
 
Iscritto dal: May 2004
Città: Londra (Torino)
Messaggi: 3692
Ah si' scusa.
Ho pensato alla Successors ed ho una soluzione davvero molto semplice, stasera te la posto.
Per la predecessors dovrebbe essere molto molto simile.
__________________
Se pensi che il tuo codice sia troppo complesso da capire senza commenti, e' segno che molto probabilmente il tuo codice e' semplicemente mal scritto.
E se pensi di avere bisogno di un nuovo commento, significa che ti manca almeno un test.
gugoXX è offline   Rispondi citando il messaggio o parte di esso
Old 04-03-2008, 20:39   #8
gugoXX
Senior Member
 
L'Avatar di gugoXX
 
Iscritto dal: May 2004
Città: Londra (Torino)
Messaggi: 3692
Eccomi.
La soluzione algoritmica dovrebbe funzionare.
Putroppo l'ho scritta in C# perche' il Java non lo conosco, ma dovrebbe essere adattabile.
Se definisco una classe nodo ragionevolmente come segue:
Codice:
public class Node
{
     public Node Padre;
     public Node FiglioSinistro;
     public Node FiglioDestro;
     public int valore;
}
Allora un metodo per ottenere i successori potrebbe essere il seguente:
Codice:
public class AlberoRedBlack
{
    public Node root;
    public IEnumerable<int> Successors(int n)
    {
        return Successors(root, n);
    }

    private static IEnumerable<int> Successors(Node Kn,int n)
    {
        if (Kn.valore > n)
        {
            if (Kn.FiglioSinistro != null)
            {
                foreach (int ret in Successors(Kn.FiglioSinistro, n)) yield return ret;
            }
        }

        if (Kn.valore>=n) yield return Kn.valore;  

        if (Kn.FiglioDestro != null)
        {
            foreach (int ret in Successors(Kn.FiglioDestro, n)) yield return ret;
        }                    
    }
}
In modo tale da poter usare l'enumeratore in un ciclo come questo
Codice:
     AlberoRedBlack albero = new AlberoRedBlack();
     albero.Load(...qualcosa...);
     foreach (int ret in albero.Successors(9))
     {
         Console.WriteLine(ret);
     }

Non so se Java supporta una sitassi come questa dello
yield return
In pratica lo yield return serve per restituire immediatamente al chiamate un valore dell'enumerazione, che potra' pero' continuare dallom stesso punto in cui si trovava, compreso il livello di ricorsione.
In pratica inizio a navigare l'albero verso sinistra.
Per ogni nodo controllo se il valore e' maggiore della soglia. Se non lo e' magari ho qualche nodo nel sottoalbero di sinistra che devo restituire, che dovra' anche essere il primo restituito dato che li vuoi in ordine non decrescente.
A quel punto entro in ricorsione, fino a che non posso iniziare a restuire veramente qualcosa.

Onestamente pensavo il metodo ricorsivo fosse ancora piu' semplice di cosi'. Avrei sperato di ritornare direttamente l'Enumeratore da ciascun figlio al proprio padre durante la ricorsione.
Non me lo faceva compilare cosi' l'ho dovuto adattare in questo modo, cosi' ho dovuto svolgere i cicli di ciascuno dei due rami.
Ma grazie allo yield il valore viene ritornato direttamente al chiamante.

Il metodo dovrebbe essere l'ottimo, in quanto se non sbaglio viene fatto il minor numero di confronti possibile. Magari si puo' lavorare sulla pulizia del codice, ma ora devo scappare.

Ciau.
__________________
Se pensi che il tuo codice sia troppo complesso da capire senza commenti, e' segno che molto probabilmente il tuo codice e' semplicemente mal scritto.
E se pensi di avere bisogno di un nuovo commento, significa che ti manca almeno un test.

Ultima modifica di gugoXX : 04-03-2008 alle 20:42.
gugoXX è offline   Rispondi citando il messaggio o parte di esso
Old 05-03-2008, 23:53   #9
Skarafaz
Senior Member
 
L'Avatar di Skarafaz
 
Iscritto dal: May 2006
Città: Rovigo
Messaggi: 442
GRAZIE MILLE!!!! L'algoritmo mi sembra buono, ora mi metto al lavoro sul codice!!!
Skarafaz è offline   Rispondi citando il messaggio o parte di esso
 Rispondi


Sony Alpha 7 V, anteprima e novità della nuova 30fps, che tende la mano anche ai creator Sony Alpha 7 V, anteprima e novità della ...
realme GT 8 Pro Dream Edition: prestazioni da flagship e anima racing da F1 realme GT 8 Pro Dream Edition: prestazioni da fl...
OVHcloud Summit 2025: le novità del cloud europeo tra sovranità, IA e quantum OVHcloud Summit 2025: le novità del cloud...
Un mostro da MSI: QD-OLED WQHD a 500 Hz con AI Care e DisplayPort 2.1a Un mostro da MSI: QD-OLED WQHD a 500 Hz con AI C...
DJI Neo 2 in prova: il drone da 160 grammi guadagna il gimbal e molto altro DJI Neo 2 in prova: il drone da 160 grammi guada...
Scoperto grande ''filamento cosmico'' do...
Il razzo spaziale cinese Landspace Zhuqu...
Micron uccide Crucial e dice addio agli ...
Il cosmonauta Oleg Artemyev non sar&agra...
Samsung conferma il nuovo Exynos 2600: p...
Una tecnologia spaziale verrà uti...
Anche a Bergamo controlli sulle e-bike: ...
Mario Kart World, con l'ultimo aggiornam...
Oracle apre una seconda Region per il cl...
Euro NCAP 2026, cambiano completamente i...
In Russia centinaia di Porsche diventano...
Gli operatori mobile italiani offrono se...
realme GT 8 Pro in promo lancio con 100€...
Autostrade, dal 2026 arrivano i rimborsi...
Carenza di memoria flash NAND e prezzi a...
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: 05:13.


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