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í
×
    včera 07:33 | Komunita

    O víkendu probíhá konference OpenAlt 2025. Na programu je spousta zajímavých přednášek. Pokud jste v Brně, stavte se. Vstup zdarma.

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

    Josef Průša představil novou velkoformátovou uzavřenou CoreXY 3D tiskárnu Prusa CORE One L a nový open source standard chytrých cívek OpenPrintTag i s novou přepracovanou špulkou.

    Ladislav Hagara | Komentářů: 7
    31.10. 18:33 | IT novinky

    Na GOG.com běží Autumn Sale. Při té příležitosti je zdarma hororová počítačová hra STASIS (ProtonDB: Platinum).

    Ladislav Hagara | Komentářů: 0
    31.10. 13:22 | Komunita

    Ubuntu 25.10 má nově balíčky sestavené také pro úroveň mikroarchitektury x86-64-v3 (amd64v3).

    Ladislav Hagara | Komentářů: 8
    31.10. 01:22 | Nová verze

    Byla vydána verze 1.91.0 programovacího jazyka Rust (Wikipedie). Podrobnosti v poznámkách k vydání. Vyzkoušet Rust lze například na stránce Rust by Example.

    Ladislav Hagara | Komentářů: 0
    31.10. 00:11 | IT novinky

    Ministerstvo průmyslu a obchodu vyhlásilo druhou veřejnou soutěž v programu TWIST, který podporuje výzkum, vývoj a využití umělé inteligence v podnikání. Firmy mohou získat až 30 milionů korun na jeden projekt zaměřený na nové produkty či inovaci podnikových procesů. Návrhy projektů lze podávat od 31. října do 17. prosince 2025. Celková alokace výzvy činí 800 milionů korun.

    Ladislav Hagara | Komentářů: 5
    30.10. 23:44 | Komunita

    Google v srpnu oznámil, že na „certifikovaných“ zařízeních s Androidem omezí instalaci aplikací (včetně „sideloadingu“) tak, že bude vyžadovat, aby aplikace byly podepsány centrálně registrovanými vývojáři s ověřenou identitou. Iniciativa Keep Android Open se to snaží zvrátit. Podepsat lze otevřený dopis adresovaný Googlu nebo petici na Change.org.

    Ladislav Hagara | Komentářů: 0
    30.10. 15:22 | Nová verze

    Byla vydána nová verze 18 integrovaného vývojového prostředí (IDE) Qt Creator. S podporou Development Containers. Podrobný přehled novinek v changelogu.

    Ladislav Hagara | Komentářů: 2
    30.10. 12:55 | Nová verze

    Cursor (Wikipedie) od společnosti Anysphere byl vydán ve verzi 2.0. Jedná se o multiplatformní proprietární editor kódů s podporou AI (vibe coding).

    Ladislav Hagara | Komentářů: 1
    30.10. 02:55 | Nová verze

    Google Chrome 142 byl prohlášen za stabilní. Nejnovější stabilní verze 142.0.7444.59 přináší řadu novinek z hlediska uživatelů i vývojářů. Podrobný přehled v poznámkách k vydání. Opraveno bylo 20 bezpečnostních chyb. Za nejvážnější z nich bylo vyplaceno 50 000 dolarů. Vylepšeny byly také nástroje pro vývojáře.

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

    Dotaz: Ulohy k procviceni

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

    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.