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 21:00 | Nová verze

    Po 9 týdnech vývoje od vydání Linuxu 7.0 oznámil Linus Torvalds vydání Linuxu 7.1. Přehled novinek a vylepšení na LWN.net: první a druhá polovina začleňovacího okna a časem také na Linux Kernel Newbies.

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

    Cheat Engine (Wikipedie) je s verzí 7.7 k dispozici už také pro Linux. Jedná se o proprietární skener/debugger paměti používaný především k cheatování v počítačových hrách.

    Ladislav Hagara | Komentářů: 0
    13.6. 15:22 | IT novinky

    Vláda USA nařídila společnosti Anthropic pozastavit přístup k modelům Fable 5 a Mythos 5 pro všechny cizince, včetně zaměstnanců Anthropicu.

    Ladislav Hagara | Komentářů: 7
    13.6. 02:22 | Nová verze

    Společnost Murena představila (YouTube) novou verzi 4.0 mobilního operačního systému /e/OS (Wikipedie) založeného na Androidu a LineageOS bez aplikací a služeb od Googlu.

    Ladislav Hagara | Komentářů: 0
    12.6. 16:33 | Bezpečnostní upozornění

    V Arch User Repository (AUR) bylo kompromitováno přes 400 opomíjených balíčků (jejich seznam). Útočník do nich začlenil škodlivý npm balíček atomic-lockfile, který krade citlivá data uživatelů. Publikována byla předběžná analýza spouštěného malwaru deps.

    Ladislav Hagara | Komentářů: 13
    12.6. 11:33 | Nová verze

    Homebrew, správce balíčků nejen pro macOS, byl vydán ve verzi 6.0.0 (seznam změn). Hlavními novinkami jsou bezpečnostní mechanismus tap trust kvůli důvěryhodnosti závislostí, vylepšení sandboxingu na Linuxu, interní JSON API nebo zlepšení výkonu.

    |🇵🇸 | Komentářů: 0
    12.6. 03:33 | Bezpečnostní upozornění

    Byla nalezena a 9. června opravena kritická zranitelnost ve FreeBSD v Kernel TLS (KTLS). Pojmenována byla Bumsrakete (FreeBSD-SA-26:26.ktls, CVE-2026-45257). Lokální neprivilegovaný uživatel může přepisovat soubory, ke kterým má právo pouze pro čtení. Přepsáním setuid binárky a jejím spuštěním může získat roota. Na všech verzích od verze 13.0 vydané v dubnu 2021.

    Ladislav Hagara | Komentářů: 2
    11.6. 14:11 | Komunita

    Vývojáři open source operačního systému ReactOS (Wikipedie), jehož cílem je kompletní binární kompatibilita s aplikacemi a ovladači pro Windows, se na síti 𝕏 pochlubili, že ReactOS zvládne počítačovou hru Half-Life.

    Ladislav Hagara | Komentářů: 5
    11.6. 10:44 | Nová verze

    Byla vydána nová verze 4.8 multiplatformního integrovaného vývojového prostředí (IDE) pro rychlý vývoj aplikaci (RAD) ve Free Pascalu Lazarus (Wikipedie). Využíván je Free Pascal Compiler (FPC) 3.2.2.

    Ladislav Hagara | Komentářů: 0
    11.6. 04:44 | Nová verze

    Apple container dospěl do verze 1.0.0. Jedná se o open source nástroj pro spouštění linuxových kontejnerů na macOS postavený nad containerization. Napsaný je v programovacím jazyce Swift a optimalizovaný pro Apple silicon.

    Ladislav Hagara | Komentářů: 5
    Které desktopové prostředí na Linuxu používáte?
     (11%)
     (8%)
     (2%)
     (16%)
     (31%)
     (3%)
     (6%)
     (3%)
     (15%)
     (26%)
    Celkem 1908 hlasů
     Komentářů: 30, poslední 3.4. 20:20
    Rozcestník


    Dotaz: Rand v C++

    7.4.2012 12:46 MarF
    Rand v C++
    Přečteno: 583×
    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.