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 02:20 | Zajímavý článek

David Revoy, autor open source webového komiksu Pepper&Carrot nebo portrétu GNU/Linuxu, upozorňuje na svém blogu, že nový Inkscape 0.92 rozbíjí dokumenty vytvořené v předchozích verzích Inkscape. Problém by měl být vyřešen v Inkscape 0.92.2 [reddit].

Ladislav Hagara | Komentářů: 0
dnes 02:02 | Komunita

Øyvind Kolås, hlavní vývojář grafických knihoven GEGL a babl, které využívá grafický program GIMP, žádá o podporu na Patreonu. Díky ní bude moci pracovat na vývoji na plný úvazek. Milník 1000 $, který by stačil na holé přežití, se již téměř podařilo vybrat, dalším cílem je dosažení 2500 $, které mu umožní běžně fungovat ve společnosti.

xkomczax | Komentářů: 1
včera 23:54 | Pozvánky

DevConf.cz 2017, již devátý ročník jedné z největších akcí zaměřených na Linux a open source ve střední Evropě, proběhne od pátku 27. ledna do neděle 29. ledna v prostorách Fakulty informačních technologií Vysokého učení technického v Brně. Na programu je celá řada zajímavých přednášek a workshopů. Letos je povinná registrace.

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

Byla vydána verze 1.0.0 emulátoru terminálu Terminology postaveného nad EFL (Enlightenment Foundation Libraries). Přehled novinek v poznámkách k vydání.

Ladislav Hagara | Komentářů: 0
20.1. 17:00 | Nová verze

Byl vydán Docker 1.13. Přehled novinek na YouTube a v poznámkách k vydání na GitHubu. Docker umožňuje běh aplikací v softwarových kontejnerech (Wikipedia).

Ladislav Hagara | Komentářů: 3
20.1. 15:51 | Komunita

Mozilla.cz informuje, že nástroje pro webové vývojáře se možná oddělí od Firefoxu a stanou doplňkem. Nástroje pro webové vývojáře prošly velkým přepisem a tým, který se stará o jejich vývoj, by uvítal možnost jejich častějších aktualizacích nezávisle na vydávání nových verzí Firefoxu.

Ladislav Hagara | Komentářů: 7
20.1. 07:00 | Humor

Čtenářům AbcLinuxu vše nejlepší k dnešnímu Dni zvýšení povědomí o tučňácích (Penguin Awareness Day).

Ladislav Hagara | Komentářů: 0
20.1. 06:00 | Komunita

Bylo spuštěno hlasování o přednáškách a workshopech pro letošní InstallFest, jenž proběhne o víkendu 4. a 5. března v Praze. Současně byla oznámena změna místa. InstallFest se letos vrací zpět na Karlovo náměstí do budovy E.

Ladislav Hagara | Komentářů: 0
20.1. 02:48 | Komunita

Greg Kroah-Hartman potvrdil, že Linux 4.9 je jádrem s prodlouženou upstream podporou (LTS, Long Term Support). Podpora je plánována do ledna 2019. Aktuální jádra s prodlouženou podporou jsou tedy 3.2, 3.4, 3.10, 3.12, 3.16, 3.18, 4.1, 4.4 a 4.9.

Ladislav Hagara | Komentářů: 0
20.1. 00:11 | Zajímavý článek

Výrobce síťových prvků, společnost Netgear, spustila nový program, který slibuje vývojářům, expertům, ale i běžným uživatelům vyplacení finanční odměny za nalezení bezpečnostních chyby v jejich produktech. Za nalezení zranitelnosti v hardware, API nebo mobilní aplikaci nabízí odměnu od 150 do 15 tisíc dolarů (dle závažnosti).

Michal Makovec | Komentářů: 0
Jak se stavíte k trendu ztenčování přenosných zařízení (smartphony, notebooky)?
 (10%)
 (2%)
 (74%)
 (3%)
 (10%)
Celkem 353 hlasů
 Komentářů: 25, poslední včera 13:34
    Rozcestník
    Reklama

    Dotaz: Rand v C++

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