Hash knihovny pro programátory C

click fraud protection

Tato stránka obsahuje seznam knihoven, které vám pomohou při programování v C. Knihovny jsou otevřeným zdrojovým kódem a používají se k ukládání dat, aniž by bylo nutné převádět vlastní propojený seznam atd. Datové struktury.

Vyvinuto Troyem D. Hansone, jakoukoli strukturu C lze pomocí hash tabulky uložit uthash. Stačí přidat #include "uthash.h", pak do struktury přidejte UT_hash_handle a vyberte jedno nebo více polí ve své struktuře, která budou fungovat jako klíč. Poté použijte HASH_ADD_INT, HASH_FIND_INT a makra k uložení, načtení nebo odstranění položek z tabulky hash. Používá int, string a binární klíče.

Jitka je knihovna C, která implementuje řídké dynamické pole. Jitka pole jsou deklarovány jednoduše nulou ukazatel a spotřebovávají paměť, pouze pokud jsou naplněny. V případě potřeby mohou růst a využívat veškerou dostupnou paměť. Mezi hlavní výhody Judy patří škálovatelnost, vysoký výkon a efektivita paměti. Může být použit pro dynamicky velká pole, asociativní pole nebo snadno použitelné rozhraní, které nevyžaduje žádné další úpravy pro rozšíření nebo kontrakci a může nahradit mnoho běžné datové struktury, jako jsou pole, řídká pole, hashovací tabulky, B-stromy, binární stromy, lineární seznamy, skiplists, jiné algoritmy řazení a vyhledávání a počítání funkce.

instagram viewer

SGLIB je zkratka pro Simple Generic Library a skládá se z jediného souboru záhlaví sglib.h, který poskytuje obecnou implementaci nejběžnějších algoritmů pro pole, seznamy, tříděné seznamy a červeno-černé stromy. Knihovna je obecná a nedefinuje své vlastní datové struktury. Spíše působí na existující uživatelem definované datové struktury prostřednictvím generického rozhraní. Nepřiděluje ani nepřiděluje žádnou paměť a nezávisí na žádné konkrétní správě paměti.

Všechny algoritmy jsou implementovány ve formě maker parametrizovaných typem datové struktury a funkce komparátoru (nebo komparátorového makra). Pro některé algoritmy a datové struktury může být vyžadováno několik dalších obecných parametrů, jako je název „dalšího“ pole pro propojené seznamy.

instagram story viewer