Torna indietro   Hardware Upgrade Forum > Software > Programmazione

Hisense A85N: il ritorno all’OLED è convincente e alla portata di tutti
Hisense A85N: il ritorno all’OLED è convincente e alla portata di tutti
Dopo alcuni anni di assenza dai cataloghi dei suoi televisori, Hisense riporta sul mercato una proposta OLED che punta tutto sul rapporto qualità prezzo. Hisense 55A85N è un televisore completo e versatile che riesce a convincere anche senza raggiungere le vette di televisori di altra fascia (e altro prezzo)
Recensione Borderlands 4, tra divertimento e problemi tecnici
Recensione Borderlands 4, tra divertimento e problemi tecnici
Gearbox Software rilancia la saga con Borderlands 4, ora disponibile su PS5, Xbox Series X|S e PC. Tra le novità spiccano nuove abilità di movimento, un pianeta inedito da esplorare e una campagna che lascia al giocatore piena libertà di approccio
TCL NXTPAPER 60 Ultra: lo smartphone che trasforma la lettura da digitale a naturale
TCL NXTPAPER 60 Ultra: lo smartphone che trasforma la lettura da digitale a naturale
NXTPAPER 60 Ultra è il primo smartphone con tecnologia NXTPAPER 4.0 per il display, un ampio IPS da 7,2 pollici. Con finitura anti-riflesso, processore MediaTek Dimensity 7400, fotocamera periscopica e modalità Max Ink per il detox digitale, NXTPAPER 60 Ultra punta a essere il riferimento tra gli smartphone pensati per il benessere degli occhi.
Tutti gli articoli Tutte le news

Vai al Forum
Rispondi
 
Strumenti
Old 01-03-2008, 14: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, 12: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, 13: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 13:02.
gugoXX è offline   Rispondi citando il messaggio o parte di esso
Old 02-03-2008, 13: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, 13: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, 15: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, 17: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, 19: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 19:42.
gugoXX è offline   Rispondi citando il messaggio o parte di esso
Old 05-03-2008, 22: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


Hisense A85N: il ritorno all’OLED è convincente e alla portata di tutti Hisense A85N: il ritorno all’OLED è convi...
Recensione Borderlands 4, tra divertimento e problemi tecnici Recensione Borderlands 4, tra divertimento e pro...
TCL NXTPAPER 60 Ultra: lo smartphone che trasforma la lettura da digitale a naturale TCL NXTPAPER 60 Ultra: lo smartphone che trasfor...
Un fulmine sulla scrivania, Corsair Sabre v2 Pro ridefinisce la velocità nel gaming Un fulmine sulla scrivania, Corsair Sabre v2 Pro...
Nokia Innovation Day 2025: l’Europa ha bisogno di campioni nelle telecomunicazioni Nokia Innovation Day 2025: l’Europa ha bisogno d...
Amazon sorprende: iPhone 16 crolla a 699...
Fundo.one, la prima startup finanziata d...
Telegram al centro delle elezioni in Mol...
Densità energetica triplicata ris...
Nuove regole per l'AI di Meta: niente co...
iPhone 16 in Bianco e altri 2 colori a s...
Microsoft rimuove il blocco dell'aggiorn...
TikTok 'MAGA al 100%': Trump vuole modif...
Stuttering e freeze sui laptop da 3.000 ...
Government Data Intelligence for Agricul...
iPhone 17e limitato per non oscurare iPh...
Windows 11 può usare l'IA per cla...
Microsoft Edge diventa più sicuro...
Yakuza Kiwami 3: il nuovo trailer mostra...
Geely lo fa davvero: auto con garanzia 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: 13:36.


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