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 01:00 | Komunita

    Debian dnes slaví 32 let. Ian Murdock oznámil vydání "Debian Linux Release" 16. srpna 1993.

    Ladislav Hagara | Komentářů: 12
    15.8. 17:44 | IT novinky

    Policisté zadrželi odsouzeného drogového dealera Tomáše Jiřikovského, který daroval ministerstvu spravedlnosti za tehdejšího ministra Pavla Blažka (ODS) bitcoiny v miliardové hodnotě, a zajistili i darovanou kryproměnu. Zadržení Jiřikovského může být podle ministerstva důležité k rozuzlení kauzy, která vypukla koncem května a vedla ke konci Blažka. Zajištění daru podle úřadu potvrzuje závěry dříve publikovaných právních

    … více »
    Ladislav Hagara | Komentářů: 7
    15.8. 13:44 | IT novinky

    Administrativa amerického prezidenta Donalda Trumpa jedná o možném převzetí podílu ve výrobci čipů Intel. Agentuře Bloomberg to řekly zdroje obeznámené se situací. Akcie Intelu v reakci na tuto zprávu výrazně posílily. Trump minulý týden označil Tana za konfliktní osobu, a to kvůli jeho vazbám na čínské společnosti, čímž vyvolal nejistotu ohledně dlouholetého úsilí Intelu o obrat v hospodaření. Po pondělní schůzce však prezident o šéfovi Intelu hovořil příznivě.

    Ladislav Hagara | Komentářů: 3
    15.8. 05:44 | IT novinky

    Společnost Purism stojící za linuxovými telefony a počítači Librem má nově v nabídce postkvantový šifrátor Librem PQC Encryptor.

    Ladislav Hagara | Komentářů: 10
    14.8. 18:00 | Nová verze

    VirtualBox, tj. multiplatformní virtualizační software, byl vydán v nové verzi 7.2. Přehled novinek v Changelogu. Vypíchnou lze vylepšené GUI.

    Ladislav Hagara | Komentářů: 0
    14.8. 14:11 | IT novinky

    Eric Migicovsky, zakladatel společnosti Pebble, v lednu oznámil, že má v plánu spustit výrobu nových hodinek Pebble s již open source PebbleOS. V březnu spustil předprodej hodinek Pebble Time 2 (tenkrát ještě pod názvem Core Time 2) za 225 dolarů s dodáním v prosinci. Včera představil jejich konečný vzhled (YouTube).

    Ladislav Hagara | Komentářů: 28
    14.8. 12:44 | Zajímavý software

    Byla oznámena nativní podpora protokolu ACME (Automated Certificate Management Environment) ve webovém serveru a reverzní proxy NGINX. Modul nginx-acme je zatím v preview verzi.

    Ladislav Hagara | Komentářů: 1
    14.8. 12:22 | Nová verze

    Vývojáři KDE oznámili vydání balíku aplikací KDE Gear 25.08. Přehled novinek i s náhledy a videi v oficiálním oznámení.

    Ladislav Hagara | Komentářů: 0
    13.8. 11:55 | IT novinky

    Společnost Perplexity AI působící v oblasti umělé inteligence (AI) podala nevyžádanou nabídku na převzetí webového prohlížeče Chrome internetové firmy Google za 34,5 miliardy dolarů (zhruba 723 miliard Kč). Informovala o tom včera agentura Reuters. Upozornila, že výše nabídky výrazně převyšuje hodnotu firmy Perplexity. Společnost Google se podle ní k nabídce zatím nevyjádřila.

    Ladislav Hagara | Komentářů: 5
    13.8. 04:33 | Bezpečnostní upozornění

    Intel vydal 34 upozornění na bezpečnostní chyby ve svých produktech. Současně vydal verzi 20250812 mikrokódů pro své procesory řešící 6 bezpečnostních chyb.

    Ladislav Hagara | Komentářů: 0
    Kolik tabů máte standardně otevřeno ve web prohlížeči?
     (52%)
     (19%)
     (4%)
     (5%)
     (2%)
     (1%)
     (1%)
     (17%)
    Celkem 406 hlasů
     Komentářů: 23, poslední 4.8. 13:01
    Rozcestník

    Dotaz: Ulohy k procviceni

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

    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.