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í
×
    21.11. 22:33 | Zajímavý software

    Hru Warhammer: Vermintide 2 (ProtonDB) lze na Steamu získat zdarma napořád, když aktivaci provedete do pondělí 24. listopadu.

    Ladislav Hagara | Komentářů: 1
    21.11. 19:33 | Nová verze Ladislav Hagara | Komentářů: 0
    21.11. 13:11 | IT novinky

    Evropská komise schválila český plán na poskytnutí státní pomoci v objemu 450 milionů eur (téměř 11 miliard Kč) na rozšíření výroby amerického producenta polovodičů onsemi v Rožnově pod Radhoštěm. Komise o tom informovala v dnešní tiskové zprávě. Společnost onsemi by podle ní do nového závodu v Rožnově pod Radhoštěm měla investovat 1,64 miliardy eur (téměř 40 miliard Kč).

    Ladislav Hagara | Komentářů: 13
    21.11. 06:11 | Komunita

    Microsoft v příspěvku na svém blogu věnovaném open source oznámil, že textové adventury Zork I, Zork II a Zork III (Wikipedie) jsou oficiálně open source pod licencí MIT.

    Ladislav Hagara | Komentářů: 0
    21.11. 05:55 | Komunita

    První prosincový týden proběhne SUSE Hack Week 25. Zaměstnanci SUSE mohou věnovat svůj pracovní čas libovolným open source projektům, například přidání AI agenta do Bugzilly, implementaci SSH v programovacím jazyce Zig nebo portaci klasických her na Linux. Připojit se může kdokoli.

    Ladislav Hagara | Komentářů: 2
    20.11. 22:00 | IT novinky

    Google oznámil, že Quick Share na Androidu funguje s AirDropem na iOS. Zatím na telefonech Pixel 10. Uživatelé tak mohou snadno přenášet soubory z telefonů s Androidem na iPhony a obráceně.

    Ladislav Hagara | Komentářů: 2
    20.11. 21:22 | Nová verze

    Byla vydána nová verze 8.5 (8.5.0) skriptovacího jazyka PHP používaného zejména k vývoji dynamických webových stránek. Přináší řadu novinek a vylepšení (URI Extension, Pipe Operator, Clone With, …). Vydána byla také příručka pro přechod z předchozích verzí.

    Ladislav Hagara | Komentářů: 0
    20.11. 12:44 | IT novinky

    Evropská komise zahájila tři vyšetřování týkající se cloudových platforem Amazon Web Services (AWS) a Microsoft Azure. Evropská exekutiva, která plní také funkci unijního antimonopolního orgánu, chce mimo jiné určit, zda jsou americké společnosti Microsoft a Amazon v cloudových službách takzvanými gatekeepery, tedy hráči, kteří významně ovlivňují provoz internetu a musí dle nařízení o digitálních trzích (DMA) na společném trhu

    … více »
    Ladislav Hagara | Komentářů: 4
    20.11. 12:33 | IT novinky

    Společnost Meta Platforms vyhrála ostře sledovaný spor o akvizici sítě pro sdílení fotografií Instagram a komunikační aplikace WhatsApp. Podle amerického soudu firma jejich převzetím neporušila antimonopolní zákon, protože si tak nemonopolizovala trh sociálních sítí. Žalobu na Metu podala před pěti lety americká Federální obchodní komise (FTC). FTC argumentovala, že Meta, tehdy známá jako Facebook, koupila tyto dvě společnosti v letech 2012 a 2014 proto, aby s nimi nemusela soutěžit.

    Ladislav Hagara | Komentářů: 0
    20.11. 05:11 | IT novinky

    Home Assistant včera představil svůj nejnovější oficiální hardware: Home Assistant Connect ZBT-2 pro připojení zařízení na sítích Zigbee nebo Thread.

    Ladislav Hagara | Komentářů: 5
    Jaké řešení používáte k vývoji / práci?
     (35%)
     (46%)
     (19%)
     (18%)
     (22%)
     (15%)
     (23%)
     (16%)
     (17%)
    Celkem 387 hlasů
     Komentářů: 17, poslední 19.11. 21:57
    Rozcestník

    Dotaz: Ulohy k procviceni

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

    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.