abclinuxu.cz AbcLinuxu.cz itbiz.cz ITBiz.cz HDmag.cz HDmag.cz abcprace.cz AbcPráce.cz
Inzerujte na AbcPráce.cz od 950 Kč
Rozšířené hledání
×
    dnes 11:22 | Zajímavý software

    Open source Atuin přináší "magickou historii shellu" aneb efektivní vyhledávání v historii příkazů a synchronizaci této historie mezi počítači. Historie je uložena v SQLite. Podporovány jsou Bash, ZSH, Fish a NuShell.

    Ladislav Hagara | Komentářů: 0
    dnes 07:00 | Nová verze

    Byla vydána nová verze 8.4 multiplatformní digitální pracovní stanice pro práci s audiem (DAW) Ardour. Přehled oprav, vylepšení a novinek v oficiálním oznámení.

    Ladislav Hagara | Komentářů: 0
    včera 21:55 | Nová verze

    Vyšla nová verze výukového softwaru GCompris 4.0. Po devíti letech práce bylo dokončeno sjednocení grafického návrhu podle stanovených pravidel a společně s 8 novými aktivitami se jejich celkový počet navýšil na 190. Od roku 2014 je aplikace přepsána z Gtk do QtQuick a díky tomu je nyní možné ji používat na různých platformách jako je GNU/Linux, Android, Windows i MacOS. Ke stažení je na stránkách aplikace nebo ve správcích softwaru daných platforem.

    Jan Papež | Komentářů: 0
    včera 21:44 | Nová verze

    Byla vydána nová vývojová verze 2.99.18 svobodné aplikace pro úpravu a vytváření rastrové grafiky GIMP. Jedná se o další krok směrem k verzi 3 postavené na GTK 3. Podrobný přehled novinek i s náhledy a videi v oznámení o vydání a v souboru NEWS na GitLabu. Stabilní verze GIMPu je 2.10.36.

    Ladislav Hagara | Komentářů: 2
    včera 18:22 | Bezpečnostní upozornění

    Na Snapcraftu byla falešná kryptoměnová peněženka Exodus (už je v karanténě). Uživatel přišel o 9 bitcoinů.

    Ladislav Hagara | Komentářů: 0
    včera 15:22 | Nová verze

    Organizace Apache Software Foundation (ASF) vydala verzi 21 integrovaného vývojového prostředí a vývojové platformy napsané v Javě NetBeans (Wikipedie). Přehled novinek na GitHubu. Instalovat lze také ze Snapcraftu a Flathubu.

    Ladislav Hagara | Komentářů: 0
    včera 07:00 | IT novinky

    Komunikační software Signal (Wikipedie) v nové beta verzi umožňuje komunikaci mezi uživateli bez prozrazení telefonního čísla. Telefonní číslo je ale nadále nutné zadat při registraci do Signalu.

    Ladislav Hagara | Komentářů: 31
    včera 00:22 | Nová verze

    Google Chrome 122 byl prohlášen za stabilní. Nejnovější stabilní verze 122.0.6261.57 přináší řadu oprav a vylepšení (YouTube). Opraveno bylo 12 bezpečnostních chyb. Vylepšeny byly také nástroje pro vývojáře.

    Ladislav Hagara | Komentářů: 0
    20.2. 15:55 | Nová verze

    Byl vydán Mozilla Firefox 123.0. Přehled novinek v poznámkách k vydání, poznámkách k vydání pro firmy a na stránce věnované vývojářům. Řešeny jsou rovněž bezpečnostní chyby. Nový Firefox 123 je již k dispozici také na Flathubu a Snapcraftu.

    Ladislav Hagara | Komentářů: 0
    20.2. 13:00 | Komunita

    Open source stavebnice STEMFIE nově podporuje TT motory. Videoukázka na YouTube.

    Ladislav Hagara | Komentářů: 0
    Kolik máte nálepek na víku notebooku?
     (17%)
     (59%)
     (5%)
     (3%)
     (6%)
     (10%)
    Celkem 357 hlasů
     Komentářů: 13, poslední včera 21:51
    Rozcestník

    Dotaz: Huffmanovo kódování

    20.9.2014 20:02 Oxydentist
    Huffmanovo kódování
    Přečteno: 533×
    Ahoj, snažím se implementovat Huffmanovo kódování. Narazil jsem na to, že vlastně nevím, jak výsledný kód uložit. Protože když ho uložím klasicky do textového nebo binárního souboru, jednotlivé znaky kódu se převedou dle ASCII, takže je vlastně výsledný soubor větší, než původní.

    'ahoj' v ASCII je 01000001 01001000 01001111 01001010. Já to zakóduju jako 01 00 11 10, ale když chci tuto část kódu uložit, transformuje se na: 0011000000110001 0011000000110000 0011000100110001 0011000100110000.

    Co s tím? Jde nějak zapisovat do (binárního) souboru po jednotlivých bitech, tak, abych z něj mohl opět číst? Dělám v Pascalu.

    Díky za rady.

    Řešení dotazu:


    Odpovědi

    20.9.2014 20:13 Kit | skóre: 45 | Brno
    Rozbalit Rozbalit vše Re: Huffmanovo kódování
    Musíš to zapsat po bitech. V daném případě bude výsledek zabírat jen jeden byte 01001110. Tento byte si musíš nejprve spočítat v Pascalu a teprve pak zapsat.
    Komentáře označují místa, kde programátor udělal chybu nebo něco nedodělal.
    20.9.2014 20:39 Oxydentist
    Rozbalit Rozbalit vše Re: Huffmanovo kódování
    Můžeš mě někam odkázat nebo trochu postrčit správnym směrem? Nějak se mi nedaří zapisovat po bitech a ani se mi nic nedaří vygooglit... Dík
    20.9.2014 20:52 Tomáš Heger (geckon) | skóre: 62 | Praha/Valašsko
    Rozbalit Rozbalit vše Re: Huffmanovo kódování
    Pomohlo by ti třeba tohle?

    Bit manipulation
    20.9.2014 21:13 Oxydentist
    Rozbalit Rozbalit vše Re: Huffmanovo kódování
    Abych se pžiznal, moc moudrý z toho nejsem. Nebylo by něco víc pro zelenáče? Nebo je manipulace s bity (v rozsahu, který potřebuju) vyšší dívčí?
    Jendа avatar 20.9.2014 23:13 Jendа | skóre: 78 | blog: Jenda | JO70FB
    Rozbalit Rozbalit vše Re: Huffmanovo kódování
    Potřebuješ v podstatě umět
    VAR
      byte x := 0
    END_VAR
    
    x := x OR (1 shl 5) { nastaví pátý bit x }
    
    (pokud jsem použil směs Basicu a Pascalu, tak se omlouvám)
    Nebo je manipulace s bity (v rozsahu, který potřebuju) vyšší dívčí?
    Není.
    20.9.2014 23:07 Sten
    Rozbalit Rozbalit vše Re: Huffmanovo kódování
    Do souborů se dá zapisovat jedině po celých bajtech. Pokud tedy máte znaky jinak velké (nejen menší, třeba u LZO jsou naopak větší), musí je váš program převést na celé bajty. To můžete udělat třeba pomocí bufferu, do kterého zapisujete jednotlivé (libovolně velké) znaky a on zapíše do výstupního souboru vždy, když nahromaděné znaky obsadí celý bajt.

    Založit nové vláknoNahoru

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

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