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 16:44 | Nová verze

    Valkey, tj. svobodný fork již nesvobodného Redisu, byl vydán v první stabilní verzi 7.2.5.

    Ladislav Hagara | Komentářů: 0
    dnes 15:11 | IT novinky

    Společnost Espressif Systems oznámila, že rodinu SoC ESP32 brzy rozšíří o ESP32-H4 s IEEE 802.15.4 a Bluetooth 5.4 (LE) s podporou protokolů Thread 1.3, Zigbee 3.0 a Bluetooth Mesh 1.1.

    Ladislav Hagara | Komentářů: 1
    dnes 13:11 | Zajímavý software

    Kevin Bentley zveřejnil na GitHubu zdrojové kódy počítačové hry Descent 3 z roku 1999: "Někdo se nedávno zeptal, zda budou zveřejněny zdrojové kódy Descent 3. Oslovil jsem svého bývalého šéfa (Matt Toschlog) z Outrage Entertainment a ten mi to povolil. Budu pracovat na tom, aby se to znovu rozběhlo a hledám spolusprávce." [Hacker News]

    Ladislav Hagara | Komentářů: 0
    dnes 04:33 | Bezpečnostní upozornění

    Byla vydána verze 0.81 telnet a ssh klienta PuTTY. Opravena je kritická bezpečnostní chyba CVE-2024-31497 obsažena ve verzích 0.68 až 0.80. Používáte-li klíč ECDSA NIST P521 a použili jste jej v PuTTY nebo Pageantu, považujte jej za kompromitovaný.

    Ladislav Hagara | Komentářů: 0
    včera 21:44 | Komunita

    Hra MineClone2 postavena nad voxelovým herním enginem Minetest byla přejmenována na VoxeLibre.

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

    Společnosti Avast Software s.r.o. byla pravomocně uložena pokuta ve výši 351 milionů Kč. Tu uložil Úřad pro ochranu osobních údajů za neoprávněné zpracování osobních údajů uživatelů jejího antivirového programu Avast a jeho rozšíření internetových prohlížečů (Browser Extensions), k čemuž docházelo prokazatelně po část roku 2019.

    … více »
    Ladislav Hagara | Komentářů: 7
    včera 15:55 | Zajímavý článek

    Bylo vydáno do češtiny přeložené číslo 714 týdeníku WeeklyOSM přinášející zprávy ze světa OpenStreetMap.

    Ladislav Hagara | Komentářů: 0
    včera 15:44 | Pozvánky

    V sobotu 20. dubna lze navštívit Maker Faire Jihlava, festival plný workshopů, interaktivních činností a především nadšených a zvídavých lidí.

    Ladislav Hagara | Komentářů: 0
    včera 14:44 | Zajímavý software

    Knihovna pro potlačení šumu RNNoise byla vydána ve verzi 0.2. Kvalitu potlačení lze vyzkoušet na webovém demu.

    Ladislav Hagara | Komentářů: 0
    včera 04:33 | Nová verze

    FRRouting (FRR) (Wikipedie), tj. softwarová sada pro směrování síťové komunikace, fork Quagga, byl vydán ve verzi 10.0.

    Ladislav Hagara | Komentářů: 0
    KDE Plasma 6
     (61%)
     (13%)
     (2%)
     (24%)
    Celkem 428 hlasů
     Komentářů: 4, poslední 6.4. 15:51
    Rozcestník

    Dotaz: Ulohy k procviceni

    9.5.2013 17:02 Petr | skóre: 29
    Ulohy k procviceni
    Přečteno: 670×

    Ahoj, shanim nejake kousky kodu k reseni uloh viz priklad nize. Mam to pro procvicovani studenta ale doma jich mam zatracene malo (jeste pozustatky z FELu) a na netu jsem nic podobneho nenasel. Nemate neco vy, nebo alespon odkazy? Diky...

    Priklad:

    Do nasledujiciho kodu doplnte chybejici konstantu v podmince tak, aby procedura xyz() byla volana prave 2100krat...

    for (i = 0; i < 70; i++)   {

    j = 0;

    do   {

    if (j > ___) xyz();

    j++;

    }   while (j < 90);

    }

    Odpovědi

    9.5.2013 17:22 NN
    Rozbalit Rozbalit vše Re: Ulohy k procviceni
    Jazyk?
    9.5.2013 17:51 Petr | skóre: 29
    Rozbalit Rozbalit vše Re: Ulohy k procviceni
    Idealne C nebo Pascal, z toho je zkouseji... (nebo neco intuitivne podobneho by asi nevadilo)
    pepe_ avatar 9.5.2013 17:54 pepe_ | skóre: 48
    Rozbalit Rozbalit vše Re: Ulohy k procviceni

    Pascal ???

    9.5.2013 18:06 Petr | skóre: 29
    Rozbalit Rozbalit vše Re: Ulohy k procviceni
    Jo, chce ted delat prijimacky na balalare na MFF informatiku davaji tam zadani (ekvivalentni) v pascalu i c... Chci mu trochu pomoct neco podobneho jsem meli tusim v "Algoritmech a datovych strukturach" na FELu :00
    9.5.2013 18:04 Petr | skóre: 29
    Rozbalit Rozbalit vše Re: Ulohy k procviceni

    Nebo neco takoveho:)

    Je dán následující program
    program AAA
    var A, B, C: integer
    begin
    read(A, B);
    while A > B do
    A := A – 2;
    while B > A do
    B := B – 2;
    C := A + B;
    writeln(C)
    end.

    Určete, jak závisí výsledná hodnota proměnné C (tzn. výstup programu) na vstupních
    hodnotách proměnných A, B.

    rADOn avatar 9.5.2013 19:07 rADOn | skóre: 44 | blog: bloK | Praha
    Rozbalit Rozbalit vše chytak
    int oops() {
         char ch = 0x80;
         switch (ch) {
         case 0x80:
             return 3;
         case 0x40:
             return 2;
         default:
             return 1;
         }
    }
    Jaky je vysledek oops() ?
    "2^24 comments ought to be enough for anyone" -- CmdrTaco
    10.5.2013 11:15 Václav Vanc | skóre: 14
    Rozbalit Rozbalit vše Re: chytak
    Může se stát, že to někdy vrátí 2? Nebo je to tam jen pro zmatení nepřítele?
    10.5.2013 11:33 DarkKnightCZ | skóre: 12
    Rozbalit Rozbalit vše Re: chytak

    ne, vzdycky to vrati jedna, protoze 0x80 je 128, kdezto char ma max hodnotu 127, takze to pretece :)

    10.5.2013 11:39 Václav Vanc | skóre: 14
    Rozbalit Rozbalit vše Re: chytak
    No to vim, že to může vrátit buď 1 nebo 3, podle toho jestli je char signed nebo ne. Zajímalo mě, jestli (třeba na nějaký exotický architektuře) to může vrátit 2... :D
    rADOn avatar 10.5.2013 13:01 rADOn | skóre: 44 | blog: bloK | Praha
    Rozbalit Rozbalit vše Re: chytak
    Ne, tim to neni. Pokud pretece incializace toho charu, tak uplne stejne pretece i konstanta ve switchi. Je to chytak - vysledek zalezi na prekladaci.
    "2^24 comments ought to be enough for anyone" -- CmdrTaco
    10.5.2013 15:36 DarkKnightCZ | skóre: 12
    Rozbalit Rozbalit vše Re: chytak

    ano, zalezi, zda bude brat 0x80 jako znak, nebo jako konstantu, pokud to bude pretypovavat, tak by to melo mit stejnou hodnotu, jinak by to melo padnout do defaultu

    10.5.2013 16:55 potato
    Rozbalit Rozbalit vše Re: chytak
    Takže toto
    If necessary, an integral promotion is performed on the controlling expression, and all expressions in the case statements are converted to the same type as the controlling expression
    neplatí, nebo je nějaký způsob, jak to interpretovat nejednoznačně? Tedy jinak, než:

    1. ch je menší než int, takže se převede na int

    2. největší společný typ ch (nyní int) a konstatních výrazů v case je int

    3. všechny konstatní výrazy v case se převedou na int

    4. porovná se

    Konstanty ve switchi podle mne přetéci nemohou, protože se jich žádný char netýká. U inicializace ch ale skutečně záleží na tom, jak se 0x80 převede do char.
    rADOn avatar 10.5.2013 17:07 rADOn | skóre: 44 | blog: bloK | Praha
    Rozbalit Rozbalit vše Re: chytak
    Čteš to blbě. Píše se tam že "výrazy v case se zkonvertují na stejný typ jako řídící výraz". Řídící výraz je neznaménkový char. 0x80 tedy přeteče, ale je to stejná operace jako když se inicializuje ch takže by se to mělo navzájem vynulovat a matchnout. Teoreticky :-)
    "2^24 comments ought to be enough for anyone" -- CmdrTaco
    rADOn avatar 10.5.2013 17:34 rADOn | skóre: 44 | blog: bloK | Praha
    Rozbalit Rozbalit vše Re: chytak
    Teď koukám že novější verze gcc už na to mají warning takže chyták se nekoná. Šlo o to že v jisté relativně nedávné verzi gcc se objevila změna: To co jsem psal výše platí (starší verze gcc vrátí 3), ale kompiler neví že se to za běhu navzájem vynuluje. Uvidí konstantu která nemůže matchnout (protože ji vidí jako int) takže celou tu case větev zahodí. Takže novější verze gcc spadnou do defaultu a vrátí jedna.

    Vzpoměl jsem si na to páčž na to kluci v práci narazili, ale jak to tak čtu tak to není vhodný příklad pro začátečníka. :-) Leda snad jako ilustrace užitečnosti -Wall.
    "2^24 comments ought to be enough for anyone" -- CmdrTaco
    11.5.2013 11:00 jekub
    Rozbalit Rozbalit vše Re: chytak
    měl jsem dojem, že řeč jde o jazyku, ne překladači
    12.5.2013 20:59 potato
    Rozbalit Rozbalit vše Re: chytak
    Že něco dopadne v různých překladačích různě, může mít různé příčiny, například:

    1. Konstrukce je undefined.

    2. Konstrukce je implementation-defined.

    3. Konstrukce se liší mezi verzemi standardu.

    4. Konstrukce je jednoznačná, ale některý překladač to překládá blbě.

    Z uvedených je pouze 4. čistě o kompilátoru. A i o ní se hodí vědět...
    10.5.2013 21:16 potato
    Rozbalit Rozbalit vše Re: chytak
    Čtu to především celé, tedy
    integral promotion is performed on the controlling expression
    tedy, je-li menší než int, tak se nejdříve povýší na int.
    12.5.2013 14:41 Jardík
    Rozbalit Rozbalit vše Re: chytak
    Bagr hrabe, char může mít i 128b, takže se běžte zahrabat.
    12.5.2013 16:26 DarkKnightCZ | skóre: 12
    Rozbalit Rozbalit vše Re: chytak

    ne, obycejny char v c nemuze mit 128b

    12.5.2013 19:55 Jardík
    Rozbalit Rozbalit vše Re: chytak
    Proč by nemohl? Protože standard určuje jeho minimální velikost (8b), tak jste někde našel jeho maximální? Máte garantováno CHAR_BIT >= 8 a sizeof(char) = 1 (byte). Ale nikde nedefinuje, že 1 byte = 8 bitů a právě toto je závislé na architektuře. 1 byte není vždy 8 bitů. Pokud např. budeme kompilovat na platformě, kde 1 char je 16 bitů, bude platit:
    CHAR_BIT = 16
    sizeof(char) = 1     // * CHAR_BIT = 16b
    sizeof(uint16_t) = 1 // * CHAR_BIT = 16b
    sizeof(uint32_t) = 2 // * CHAR_BIT = 32b
    
    Na takové platformě samozřejmě nebude definován typ uint8_t, protože architektura prostě nemá typ menší než 16b.
    12.5.2013 19:57 Jardík
    Rozbalit Rozbalit vše Re: chytak
    To výše, standardem C99. POSIX tuším určuje CHAR_BIT vždy 8, ale ruku do ohně za to nedám.
    12.5.2013 21:11 potato
    Rozbalit Rozbalit vše Re: chytak
    POSIX skutečně vyžaduje, aby CHAR_BIT byl 8. Například socketové API potřebuje oktety -- a char nemůže být větší než nejmenší adresovatelný typ.
    12.5.2013 22:33 Šangala | skóre: 56 | blog: Dutá Vrba - Wally
    Rozbalit Rozbalit vše Re: chytak
    Sem tam mám v kódu něco, čemu říkám „compile assert“ (někde schované v knihovním namespace) něco jako:
    typedef char library_assert_sizeof_char[sizeof(char) == 1 ? 1 : -1];   //have to be 1
    typedef unsigned char library_assert_sizeof_unsigned_char[sizeof(unsigned char) == 1 ? 1 : -1]; //have to be 1
    typedef char library_assert_sizeof_char_bits[ CHAR_BIT == 8 ? 1 : -1]; //sorry, this library needs it
    
    To, že trpíš stihomamem, ještě neznamená, že po tobě nejdou. ⰞⰏⰉⰓⰀⰜⰉ ⰗⰞⰅⰜⰘ ⰈⰅⰏⰉ ⰒⰑⰎⰉⰁⰕⰅ ⰏⰉ ⰒⰓⰄⰅⰎ ·:⁖⁘⁙†
    10.5.2013 16:36 kuka
    Rozbalit Rozbalit vše Re: chytak
    Napriklad v jave to moc chytak neni:-)
    wamba avatar 9.5.2013 19:00 wamba | skóre: 38 | blog: wamba
    Rozbalit Rozbalit vše Re: Ulohy k procviceni
    No pro Ruby existuje koans. I když Ruby nikterak nevyužívám, tak jsem si koans prošel a mají to podle mě dobře uděláno (celkem i zábava :))

    Existují "koans" a podobné projekty i pro jiné jazyky (více či méně dotažené).
    This would have been so hard to fix when you don't know that there is in fact an easy fix.
    Zdeněk Zámečník avatar 9.5.2013 19:10 Zdeněk Zámečník | skóre: 26
    Rozbalit Rozbalit vše Re: Ulohy k procviceni

    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.