abclinuxu.cz AbcLinuxu.cz itbiz.cz ITBiz.cz HDmag.cz HDmag.cz abcprace.cz AbcPráce.cz
AbcLinuxu hledá autory!
Inzerujte na AbcPráce.cz od 950 Kč
Rozšířené hledání
×
    dnes 21:00 | IT novinky

    Od 3. listopadu 2025 budou muset nová rozšíření Firefoxu specifikovat, zda shromažďují nebo sdílejí osobní údaje. Po všech rozšířeních to bude vyžadováno někdy v první polovině roku 2026. Tyto informace se zobrazí uživateli, když začne instalovat rozšíření, spolu s veškerými oprávněními, která rozšíření požaduje.

    Ladislav Hagara | Komentářů: 0
    dnes 17:11 | Humor

    Jste nuceni pracovat s Linuxem? Chybí vám pohodlí, které vám poskytoval Microsoft, když vás špehoval a sledoval všechno, co děláte? Nebojte se. Recall for Linux vám vrátí všechny skvělé funkce Windows Recall, které vám chyběly.

    Ladislav Hagara | Komentářů: 1
    dnes 16:11 | Komunita

    Společnost Fre(i)e Software oznámila, že má budget na práci na Debianu pro tablety s cílem jeho vyžívání pro vzdělávací účely. Jako uživatelské prostředí bude použito Lomiri.

    Ladislav Hagara | Komentářů: 0
    včera 17:11 | IT novinky

    Proběhla hackerská soutěž Pwn2Own Ireland 2025. Celkově bylo vyplaceno 1 024 750 dolarů za 73 unikátních zranitelností nultého dne (0-day). Vítězný Summoning Team si odnesl 187 500 dolarů. Shrnutí po jednotlivých dnech na blogu Zero Day Initiative (1. den, 2. den a 3. den) a na YouTube.

    Ladislav Hagara | Komentářů: 3
    včera 13:33 | Komunita

    Byl publikován říjnový přehled dění a novinek z vývoje Asahi Linuxu, tj. Linuxu pro Apple Silicon. Pracuje se na podpoře M3. Zanedlouho vyjde Fedora Asahi Remix 43. Vývojáře lze podpořit na Open Collective a GitHub Sponsors.

    Ladislav Hagara | Komentářů: 0
    25.10. 15:44 | Zajímavý software

    Iniciativa Open Device Partnership (ODP) nedávno představila projekt Patina. Jedná se o implementaci UEFI firmwaru v Rustu. Vývoj probíhá na GitHubu. Zdrojové kódy jsou k dispozici pod licencí Apache 2.0. Nejnovější verze Patiny je 13.0.0.

    Ladislav Hagara | Komentářů: 0
    25.10. 05:11 | Zajímavý článek

    Obrovská poptávka po plynových turbínách zapříčinila, že datová centra začala používat v generátorech dodávajících energii pro provoz AI staré dobré proudové letecké motory, konvertované na plyn. Jejich výhodou je, že jsou menší, lehčí a lépe udržovatelné než jejich průmyslové protějšky. Proto jsou ideální pro dočasné nebo mobilní použití.

    karkar | Komentářů: 9
    24.10. 19:55 | Nová verze

    Typst byl vydán ve verzi 0.14. Jedná se o rozšiřitelný značkovací jazyk a překladač pro vytváření dokumentů včetně odborných textů s matematickými vzorci, diagramy či bibliografií.

    Ladislav Hagara | Komentářů: 0
    24.10. 13:33 | Bezpečnostní upozornění

    Specialisté společnosti ESET zaznamenali útočnou kampaň, která cílí na uživatele a uživatelky v Česku a na Slovensku. Útočníci po telefonu zmanipulují oběť ke stažení falešné aplikace údajně od České národní banky (ČNB) nebo Národní banky Slovenska (NBS), přiložení platební karty k telefonu a zadání PINu. Malware poté v reálném čase přenese data z karty útočníkovi, který je bezkontaktně zneužije u bankomatu nebo na platebním terminálu.

    Ladislav Hagara | Komentářů: 21
    24.10. 13:22 | Upozornění

    V Ubuntu 25.10 byl balíček základních nástrojů gnu-coreutils nahrazen balíčkem rust-coreutils se základními nástroji přepsanými do Rustu. Ukázalo se, že nový "date" znefunkčnil automatickou aktualizaci. Pro obnovu je nutno balíček rust-coreutils manuálně aktualizovat.

    Ladislav Hagara | Komentářů: 13
    Jaké řešení používáte k vývoji / práci?
     (36%)
     (47%)
     (20%)
     (19%)
     (23%)
     (17%)
     (21%)
     (17%)
     (18%)
    Celkem 279 hlasů
     Komentářů: 14, poslední 14.10. 09:04
    Rozcestník

    Left-Leaning Red-Black tree

    23.2.2009 20:25 | Přečteno: 1845× | Distribuce | Výběrový blog

    v souvislosti s mym predchozim zapiskem, jsem objevil moc peknou variantu red-black stromu. kdo nekdy zkousel implementovat RB stromy, AVL stromy a dalsi asi vi, ze je to pekny hnus.

    jelikoz tento prispevek pisu v dobe, kdy jenom cekam, nez mi uschnou vlasy, abych si mohl jit nakoupit, nebudu se zabyvat analyzou. obzvlast, kdyz lepsi popis za me udelali jini -- paper, slidy. (v tech slidech jsem tusim narazil na nejakou drobnou chybku, ale i tak fakt pekne shrnuti cele problematiky)

    presto, ze implementace LLRB je prosta, jak bulharska stripterka, prikladam ukazkovy priklad napsany v cecku pracujici s klici typu int a hodnotami typu char. je to kod na kterem jsem si zkousel, jestli to opravdu funguje tak jak ma. ma to operace insert (vlozeni dvojice), search (nalezeni podle klice) a print (vypis stromove struktury). snad to nekdy nekomu pomuze.

    #include <stdlib.h>
    #include <stdio.h>
    
    #define RED	(1)
    #define BLACK	(0)
    
    typedef struct rb_node {
    	int color;
    	struct rb_node * left;
    	struct rb_node * right;
    	int key;
    	char * value;
    } rb_node;
    
    
    static inline int is_red(rb_node * n)
    {
    	if (n == NULL) return 0;
    	return (n->color == RED);
    }
    
    static inline rb_node * rotate_left(rb_node * h)
    {
    	rb_node * x = h->right;
    	h->right = x->left;
    	x->left = h;
    	x->color = x->left->color;
    	x->left->color = RED;
    	return x;
    }
    
    static inline rb_node * rotate_right(rb_node * h)
    {
    	rb_node * x = h->left;
    	h->left = x->right;
    	x->right = h;
    	x->color = x->right->color;
    	x->right->color = RED;
    	return x;
    }
    
    static inline void color_flip(rb_node * h)
    {
    	h->color = !h->color;
    	h->left->color = !h->left->color;
    	h->right->color = !h->right->color;
    }
    
    static inline rb_node * node_new(int key, char * value)
    {
    	rb_node * res = malloc(sizeof(rb_node));
    	res->key = key;
    	res->value = value;
    	res->color = RED;
    	return res;
    }
    
    static rb_node * node_insert(rb_node * h, int key, char * value)
    {
    	if (h == NULL) return node_new(key, value);
    	if (is_red(h->left) && is_red(h->right)) color_flip(h);
    
    
    	if (h->key == key) h->value = value;
    	else if (h->key > key) h->left = node_insert(h->left, key, value);
    	else h->right = node_insert(h->right, key, value);
    
    	if (is_red(h->right) && !is_red(h->left)) h = rotate_left(h);
    	if (is_red(h->left) && is_red(h->left->left)) h = rotate_right(h);
    	return h;
    }
    
    rb_node * rb_insert(rb_node * root, int key, char * value) {
    	root = node_insert(root, key, value);
    	root->color = BLACK;
    	return root;
    }
    
    
    rb_node * rb_search(rb_node * h, int key)
    {
    	if ((h == NULL) || (h->key == key)) return h;
    	if (h->key > key) return rb_search(h->left, key);
    	return rb_search(h->right, key);
    }
    
    
    
    void rb_print(rb_node * h, int level)
    {
    	int i;
    	if (h == NULL) return;
    	for (i = 0; i < level; i++)
    		printf(" ");
    
    	printf("%i:%s\n", h->key, h->value);
    	rb_print(h->left, level + 1);
    	rb_print(h->right, level + 1);
    }
    
    
    int main()
    {
    	rb_node * root = NULL;
    	root = rb_insert(root, 1, "foo");
    	root = rb_insert(root, 5, "bar");
    	root = rb_insert(root, 10, "baz");
    	root = rb_insert(root, 3, "qux");
    	root = rb_insert(root, 7, "quux");
    	root = rb_insert(root, 8, "corge");
    	root = rb_insert(root, 2, "grault");
    
    	rb_print(root, 0);
    
    	printf("::%s\n", rb_search(root, 3)->value);
    
    	return 0;
    }
    
    
           

    Hodnocení: 86 %

            špatnédobré        

    Tiskni Sdílej: Linkuj Jaggni to Vybrali.sme.sk Google Del.icio.us Facebook

    Komentáře

    Vložit další komentář

    23.2.2009 20:51 Ladicek | skóre: 28 | blog: variace | Havlíčkův brod
    Rozbalit Rozbalit vše Re: Left-Leaning Red-Black tree
    Ještě mazání :-)

    Ne, když jsem dneska viděl prvně ten paper (iniciativně jsem si ho vyhledal po zmínce v té předchozí diskusi), dost mne překvapilo, jak jednoduchá ta implementace je. I like this!
    Ještě na tom nejsem tak špatně, abych četl Viewegha.
    23.2.2009 21:15 deda.jabko | skóre: 23 | blog: blog co se jmenuje "každý den jinak" | za new york city dvakrát doleva a pak už se doptáte
    Rozbalit Rozbalit vše Re: Left-Leaning Red-Black tree
    Ještě mazání :-)
    laskavy ctenar si to uz dodela sam.
    dost mne překvapilo, jak jednoduchá ta implementace je
    ...taky jsem na to cumel jak puk. ;-]
    Asi před rokem se dostali hackeři na servry Debianu a ukradli jim zdrojové kódy.
    AltOS avatar 24.2.2009 00:20 AltOS | Jizak
    Rozbalit Rozbalit vše Re: Left-Leaning Red-Black tree
    Absolutne k veci (TM):

    ...je prosta, jak bulharska stripterka...

    Plati to jeste dnes?
    24.2.2009 01:43 Deleted [8409] | skóre: 14 | blog: darkblog
    Rozbalit Rozbalit vše Re: Left-Leaning Red-Black tree
    Nebylo by lepší reorganizovat ten uzel takto?
    typedef struct rb_node {
    	struct rb_node * left;
    	struct rb_node * right;
    	int color;
    	int key;
    	char * value;
    } rb_node;
    
    Je to jen drobná změna, která by měla zmenšit celkovou velikosti struktury, pokud je int 32bitový a ukazatel 64bitový o 8 bytů (pokud je pro vás teda paměťová efektivita důležitá).
    24.2.2009 02:04 deda.jabko | skóre: 23 | blog: blog co se jmenuje "každý den jinak" | za new york city dvakrát doleva a pak už se doptáte
    Rozbalit Rozbalit vše Re: Left-Leaning Red-Black tree
    v tomto pripade to pomuze... v realnem kodu to mam stejne delane uplne jinak...

    jinak resit takove veci v ukazkovem prikladu pro deset polozek imho patri do kategorie ,,premature optimization'' a mozna i ,,immature'' ;-]
    Asi před rokem se dostali hackeři na servry Debianu a ukradli jim zdrojové kódy.
    thingie avatar 24.2.2009 02:16 thingie | skóre: 8
    Rozbalit Rozbalit vše Re: Left-Leaning Red-Black tree

    Ono, psát kód který má být tuším čistě jen ukázkou datové struktury jako smetí v Céčku se dá taky hodnotit všelijak.

    Růžové lži.
    24.2.2009 03:05 deda.jabko | skóre: 23 | blog: blog co se jmenuje "každý den jinak" | za new york city dvakrát doleva a pak už se doptáte
    Rozbalit Rozbalit vše Re: Left-Leaning Red-Black tree
    psát kód který má být tuším čistě jen ukázkou datové struktury
    ten kod jsem psal, abych si vyzkousel jestli to opravdu funguje... dal jsem to sem proto, ze kdosi ve vedlejsi diskuzi mel pripominku, ze by bylo dobre se o to podelit, protoze by se to nekomu mohlo hodit... nic vic, nic min. zadne vetsi ambice jsem s timto konkretnim kusem kodu opravdu nemel

    jako smetí v Céčku
    ted nevim jak si to mam vylozit. tim smetim jste mel na mysli:

    a) ze to neni zoptimalizovane pro 64bitovou architekturu ... viz vyse

    nebo

    b) protoze to je v cecku ,,ktere neni prehledne'' ... schvalne si prepiste ten kod treba do javy, c# nebo jineho ,,moderniho jazyka'' ... uvidime jak moc se bude lisit... btw. i v nejakem meta jazyku by to asi nevypadalo o moc jinak

    Asi před rokem se dostali hackeři na servry Debianu a ukradli jim zdrojové kódy.
    thingie avatar 24.2.2009 11:53 thingie | skóre: 8
    Rozbalit Rozbalit vše Re: Left-Leaning Red-Black tree

    Tak uvádět jako „moderní jazyk“ další a další s C-like zápisem, žejo. :-)

    (Ale tak jako jo, nebylo by to jinde nějak zásadně lepší. Leč na věci se toho tolik nemění.)

    Růžové lži.
    2.3.2009 13:39 zde | skóre: 9 | blog: Linuch | Brno
    Rozbalit Rozbalit vše Re: Left-Leaning Red-Black tree

    Implementace je to hezká, ale mě se to stejně moc nepozdává. Oproti normálním nebalancovaným i balancovaným BST je to pořád dost komplikovaný kód, a výhoda že růst uzlů částečně požerou RED linky a bude se o trošku mín rebalancovat mi to nevaváží. To už můžu rovnou místo lepení uzlů těmi horizontálními RED linky vzít nějaký vhodný násobek cacheline, uzly BST do něj skládat jako do vektoru, a budu mít B-strom s relativně malou velikostí stránky. Tahle struktura bude fakticky speciálním případem RB stromu, takže bude mít všechny jejich výhody, a navíc mnohem menší overhead (ušetří se ty červené pointery, a r/b bit).

    Táto, ty de byl? V práci, já debil.
    2.3.2009 16:37 deda.jabko | skóre: 23 | blog: blog co se jmenuje "každý den jinak" | za new york city dvakrát doleva a pak už se doptáte
    Rozbalit Rozbalit vše Re: Left-Leaning Red-Black tree
    mas to nekde naimplementovane? rad bych to srovnal v realu...
    Asi před rokem se dostali hackeři na servry Debianu a ukradli jim zdrojové kódy.
    2.3.2009 18:02 zde | skóre: 9 | blog: Linuch | Brno
    Rozbalit Rozbalit vše Re: Left-Leaning Red-Black tree

    Bohužel nemám, jen mě to napadlo, když jsem si všiml že ty 2-3-4 stromy jsou fakticky jen B-stromy s fanoutem 4, kde jsou jednotlivé bloky implementovány dalším "červeným" stromem. Poníženě přiznávám že dotěď jsem o RB stromech nic nevěděl a myslel si že jde o něco úplně jiného. Ale hlavně bych zkusil přímé indexování. Ukousnout 12 bitů, indexovat 1k tabulku, ukousnout dalších 12 bitů, indexovat další 1k tabulku, a zbylých 8 bitů použít jako finální index. Začít s prázdnou kořenovou tabulkou, a L2 a L3 tabulky alokovat podle potřeby. Myslím že tohle je ověřeno jako nejvíce efektivní metoda. Problém je jen když poslední bity mají minimální lokalitu, tak to děsně nabobtná. Ale jestli jde o pointery, tak by to mělo fungovat slušně, ne?

    Táto, ty de byl? V práci, já debil.

    Založit nové vláknoNahoru

    ISSN 1214-1267   www.czech-server.cz
    © 1999-2015 Nitemedia s. r. o. Všechna práva vyhrazena.