abclinuxu.cz AbcLinuxu.cz itbiz.cz ITBiz.cz HDmag.cz HDmag.cz abcprace.cz AbcPráce.cz
Inzerujte na AbcPráce.cz od 950 Kč
Rozšířené hledání
×
    dnes 04:55 | Zajímavý software

    Microsoft zveřejnil na GitHubu zdrojové kódy MS-DOSu 4.0 pod licencí MIT. Ve stejném repozitáři se nacházejí i před lety zveřejněné zdrojové k kódy MS-DOSu 1.25 a 2.0.

    Ladislav Hagara | Komentářů: 8
    včera 17:33 | Nová verze

    Canonical vydal (email, blog, YouTube) Ubuntu 24.04 LTS Noble Numbat. Přehled novinek v poznámkách k vydání a také příspěvcích na blogu: novinky v desktopu a novinky v bezpečnosti. Vydány byly také oficiální deriváty Edubuntu, Kubuntu, Lubuntu, Ubuntu Budgie, Ubuntu Cinnamon, Ubuntu Kylin, Ubuntu MATE, Ubuntu Studio, Ubuntu Unity a Xubuntu. Jedná se o 10. LTS verzi.

    Ladislav Hagara | Komentářů: 12
    včera 14:22 | Komunita

    Na YouTube je k dispozici videozáznam z včerejšího Czech Open Source Policy Forum 2024.

    Ladislav Hagara | Komentářů: 1
    včera 13:22 | Nová verze

    Fossil (Wikipedie) byl vydán ve verzi 2.24. Jedná se o distribuovaný systém správy verzí propojený se správou chyb, wiki stránek a blogů s integrovaným webovým rozhraním. Vše běží z jednoho jediného spustitelného souboru a uloženo je v SQLite databázi.

    Ladislav Hagara | Komentářů: 0
    včera 12:44 | Nová verze

    Byla vydána nová stabilní verze 6.7 webového prohlížeče Vivaldi (Wikipedie). Postavena je na Chromiu 124. Přehled novinek i s náhledy v příspěvku na blogu. Vypíchnout lze Spořič paměti (Memory Saver) automaticky hibernující karty, které nebyly nějakou dobu používány nebo vylepšené Odběry (Feed Reader).

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

    OpenJS Foundation, oficiální projekt konsorcia Linux Foundation, oznámila vydání verze 22 otevřeného multiplatformního prostředí pro vývoj a běh síťových aplikací napsaných v JavaScriptu Node.js (Wikipedie). V říjnu se verze 22 stane novou aktivní LTS verzí. Podpora je plánována do dubna 2027.

    Ladislav Hagara | Komentářů: 0
    včera 04:22 | Nová verze

    Byla vydána verze 8.2 open source virtualizační platformy Proxmox VE (Proxmox Virtual Environment, Wikipedie) založené na Debianu. Přehled novinek v poznámkách k vydání a v informačním videu. Zdůrazněn je průvodce migrací hostů z VMware ESXi do Proxmoxu.

    Ladislav Hagara | Komentářů: 0
    včera 04:11 | Nová verze

    R (Wikipedie), programovací jazyk a prostředí určené pro statistickou analýzu dat a jejich grafické zobrazení, bylo vydáno ve verzi 4.4.0. Její kódové jméno je Puppy Cup.

    Ladislav Hagara | Komentářů: 0
    24.4. 22:44 | IT novinky

    IBM kupuje společnost HashiCorp (Terraform, Packer, Vault, Boundary, Consul, Nomad, Waypoint, Vagrant, …) za 6,4 miliardy dolarů, tj. 35 dolarů za akcii.

    Ladislav Hagara | Komentářů: 13
    24.4. 15:55 | Nová verze

    Byl vydán TrueNAS SCALE 24.04 “Dragonfish”. Přehled novinek této open source storage platformy postavené na Debianu v poznámkách k vydání.

    Ladislav Hagara | Komentářů: 0
    KDE Plasma 6
     (73%)
     (9%)
     (2%)
     (16%)
    Celkem 780 hlasů
     Komentářů: 4, poslední 6.4. 15:51
    Rozcestník

    Dotaz: Rand v C++

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