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í
×
    dnes 10:22 | Upozornění

    Ze systému Slavia pojišťovny uniklo přibližně 150 gigabajtů citlivých dat. Jedná se například o pojistné dokumenty, lékařské záznamy nebo přímou komunikaci s klienty. Za únik může chyba dodavatelské společnosti.

    Ladislav Hagara | Komentářů: 1
    dnes 10:11 | IT novinky

    Sněmovna propustila do dalšího kola projednávání vládní návrh zákona o digitální ekonomice, který má přinést bezpečnější on-line prostředí. Reaguje na evropské nařízení DSA o digitálních službách a upravuje třeba pravidla pro on-line tržiště nebo sociální sítě a má i víc chránit děti.

    Ladislav Hagara | Komentářů: 10
    dnes 09:33 | IT novinky

    Meta převezme sociální síť pro umělou inteligenci (AI) Moltbook. Tvůrci Moltbooku – Matt Schlicht a Ben Parr – se díky dohodě stanou součástí Meta Superintelligence Labs (MSL). Meta MSL založila s cílem sjednotit své aktivity na poli AI a vyvinout takovou umělou inteligenci, která překoná lidské schopnosti v mnoha oblastech. Fungovat by měla ne jako centralizovaný nástroj, ale jako osobní asistent pro každého uživatele.

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

    Byla vydána betaverze Fedora Linuxu 44 (ChangeSet), tj. poslední zastávka před vydáním finální verze, která je naplánována na úterý 14. dubna.

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

    Open source router Turris Omnia NG Wired je v prodeji. Jedná se o Turris Omnia NG bez Wi-Fi. Je připraven pro zamontování do racku.

    Ladislav Hagara | Komentářů: 6
    včera 11:44 | Pozvánky

    Sníh roztál a roztávají i bastlíři. Žene se na nás celá řada konferencí a seminářů technického rázu. Zajímá vás, jaké? Pak se připojte k 60. Virtuální Bastlírně, tedy k veřejné diskuzi bastlířů, techniků, učitelů i vědců. Jako vždy přijde na přetřes spousta novinek ze světa hardwaru, softwaru i bizáru. Na začátek lze očekávat hardwarová témata, tedy například nový KiCAD 10, nové akcelerátory LLM s nízkou spotřebou, nejvíce fosforeskující

    … více »
    bkralik | Komentářů: 1
    včera 11:22 | Zajímavý článek

    IuRe (Iuridicum Remedium) v rámci programu Digitální svobody zveřejnila analýzu dopadů a efektivity systémů ověřování věku v digitálním prostoru, která srovnává implementace ověřování věku v Austrálii, Velké Británii a Evropské unii.

    |🇵🇸 | Komentářů: 1
    včera 04:22 | Nová verze

    Multiplatformní emulátor terminálu Ghostty byl vydán ve verzi 1.3 (𝕏, Mastodon). Přehled novinek a vylepšení v poznámkách k vydání.

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

    Byla vydána nová verze 14.4 svobodného unixového operačního systému FreeBSD. Podrobný přehled novinek v poznámkách k vydání.

    Ladislav Hagara | Komentářů: 5
    9.3. 23:22 | Nová verze

    Databáze DuckDB (Wikipedie) byla vydána ve verzi 1.5.0. S kódovým názvem Variegata (husice rajská). Přináší řadu vylepšení, včetně nového ergonomičtějšího CLI klienta nebo podporu pro typ VARIANT a vestavěný typ GEOMETRY.

    Ladislav Hagara | Komentářů: 0
    Které desktopové prostředí na Linuxu používáte?
     (16%)
     (6%)
     (0%)
     (12%)
     (29%)
     (2%)
     (5%)
     (2%)
     (12%)
     (25%)
    Celkem 1052 hlasů
     Komentářů: 25, poslední 3.2. 19:50
    Rozcestník

    Dotaz: Rand v C++

    7.4.2012 12:46 MarF
    Rand v C++
    Přečteno: 570×
    Dobrý den,

    chtěl bych vytvořit fci, která bude mít tři vstupní proměnné: spodní a horní limit a počet des. míst.

    int generuj(int a, int b) //generuje int cislo v rozsahu od a do b, d=pocet des. míst { float c; c=(rand()%99(b-a))+a;

    return c; }

    Jak ovládat počet míst za des. tečkou?

    Odpovědi

    7.4.2012 13:36 lacik
    Rozbalit Rozbalit vše Re: Rand v C++
    C++ neznám, ale asi výrazem:

    x=již vygenerované náhodné číslo

    d=počet desetinných míst

    intVal - fce odřízne desetinnou část: intVal(12.34)=12

    x=(intVal(x*d))/d
    7.4.2012 14:15 MarF
    Rozbalit Rozbalit vše Re: Rand v C++
    A ta fce intVal je ve které knihovně?
    7.4.2012 15:07 MadCatX
    Rozbalit Rozbalit vše Re: Rand v C++
    Nevím, jestli jste to myslel právě takto, nicméně tohle by mělo fungovat
    #include <cmath>
    #include <cstdio>
    #include <cstdlib>
    #include <iostream>
    
    double generuj(int min, int max, int prec)
    {
       long ex = pow(10, prec);
       double r = rand()%((max - min) * ex) + (min * ex);
       return r / ex;
    }
    
    int main(int argc, char** argv)
    {
       srand(time(NULL));
       for (int i = 0; i < 10; i++)
          printf("%.10f\n", generuj(1, 10, 5));
    
       return 0;
    }
    
    Dává výstup
    7.1701900000
    3.3656600000
    9.9872200000
    7.2741900000
    9.9646100000
    8.9658100000
    5.6601800000
    4.9083500000
    6.8956500000
    2.4416500000
    
    Funkce bude fungovat rozumně samozřejmě jen tehdy, pokud se nebudete blížit k limitům přesnosti zvoleného datového typu.
    7.4.2012 16:42 MarF
    Rozbalit Rozbalit vše Re: Rand v C++
    Díky. Mám ale problém s fcí pow

    Error 1 error C2668: 'pow' : ambiguous call to overloaded function c:\documents and settings\ibm r50e\dokumenty\visual studio 2008\projects\pokusy\pokusy\h1.cpp 42 pokusy

    knihovnu math jsem nahrál.

    7.4.2012 17:23 oiufoj
    Rozbalit Rozbalit vše Re: Rand v C++
    7.4.2012 17:25 oiufoj
    Rozbalit Rozbalit vše Re: Rand v C++
    Pokud teda nemas C++11 prekladac, nemuzes v pow pouzit cela cisla.
    7.4.2012 17:52 MarF
    Rozbalit Rozbalit vše Re: Rand v C++
    Můžeš to laikovi blíže vysvětlit? C++11 je verze? Když nemohu použít int, znamená to, že float ano?
    7.4.2012 18:10 MarF
    Rozbalit Rozbalit vše Re: Rand v C++
    Jo, už to mám, double...

    Díky
    8.4.2012 02:26 l4m4
    Rozbalit Rozbalit vše Re: Rand v C++
    Funkce bude fungovat rozumně samozřejmě jen tehdy, pokud se nebudete blížit k limitům přesnosti zvoleného datového typu.
    Budou-li se výsledky např. nějak kumulovat, tak může fungovat zcela nepoužitelně, protože různá čísla budou mít různé pravděpodobnosti.

    Je zapotřebí

    (1) Spočíst, kolik různých čísel to může generovat - N.

    (2) Při generování čísla zahodit ta, která jsou větší než (RAND_MAX/N)*N.

    (3) Pokud číslo není zahozeno, vzít ho modulo N a pak ho přepočíst na možný výsledek (to už je mapování 1:1).

    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.