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 03:33 | Nová verze

    Wayback byl vydán ve verzi 0.3. Wayback je "tak akorát Waylandu, aby fungoval Xwayland". Jedná se o kompatibilní vrstvu umožňující běh plnohodnotných X11 desktopových prostředí s využitím komponent z Waylandu. Cílem je nakonec nahradit klasický server X.Org, a tím snížit zátěž údržby aplikací X11.

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

    Byla vydána verze 4.0.0 programovacího jazyka Ruby (Wikipedie). S Ruby Box a ZJIT. Ruby lze vyzkoušet na webové stránce TryRuby. U příležitosti 30. narozenin, první veřejná verze Ruby 0.95 byla oznámena 21. prosince 1995, proběhl redesign webových stránek.

    Ladislav Hagara | Komentářů: 0
    24.12. 02:11 | Komunita

    Všem čtenářkám a čtenářům AbcLinuxu krásné Vánoce.

    Ladislav Hagara | Komentářů: 22
    24.12. 02:00 | Nová verze

    Byla vydána nová verze 7.0 linuxové distribuce Parrot OS (Wikipedie). S kódovým názvem Echo. Jedná se o linuxovou distribuci založenou na Debianu a zaměřenou na penetrační testování, digitální forenzní analýzu, reverzní inženýrství, hacking, anonymitu nebo kryptografii. Přehled novinek v příspěvku na blogu.

    Ladislav Hagara | Komentářů: 0
    23.12. 18:33 | Nová verze

    Vývojáři postmarketOS vydali verzi 25.12 tohoto před osmi lety představeného operačního systému pro chytré telefony vycházejícího z optimalizovaného a nakonfigurovaného Alpine Linuxu s vlastními balíčky. Přehled novinek v příspěvku na blogu. Na výběr jsou 4 uživatelská rozhraní: GNOME Shell on Mobile, KDE Plasma Mobile, Phosh a Sxmo.

    Ladislav Hagara | Komentářů: 0
    23.12. 13:55 | Nová verze

    Byla vydána nová verze 0.41.0 multimediálního přehrávače mpv (Wikipedie) vycházejícího z přehrávačů MPlayer a mplayer2. Přehled novinek, změn a oprav na GitHubu. Požadován je FFmpeg 6.1 nebo novější a také libplacebo 6.338.2 nebo novější.

    Ladislav Hagara | Komentářů: 0
    23.12. 12:44 | Nová verze

    Byla vydána nová verze 5.5 (novinky) skriptovacího jazyka Lua (Wikipedie). Po pěti a půl letech od vydání verze 5.4.

    Ladislav Hagara | Komentářů: 0
    22.12. 23:44 | Nová verze

    Byla vydána nová verze 5.4.0 programu na úpravu digitálních fotografií darktable (Wikipedie). Z novinek lze vypíchnout vylepšenou podporu Waylandu. Nejnovější darktable by měl na Waylandu fungovat stejně dobře jako na X11.

    Ladislav Hagara | Komentářů: 0
    21.12. 05:00 | Nová verze

    Byla vydána beta verze Linux Mintu 22.3 s kódovým jménem Zena. Podrobnosti v přehledu novinek a poznámkách k vydání. Vypíchnout lze, že nástroj Systémová hlášení (System Reports) získal mnoho nových funkcí a byl přejmenován na Informace o systému (System Information). Linux Mint 22.3 bude podporován do roku 2029.

    Ladislav Hagara | Komentářů: 2
    21.12. 01:55 | Nová verze

    GNU Project Debugger aneb GDB byl vydán ve verzi 17.1. Podrobný přehled novinek v souboru NEWS.

    Ladislav Hagara | Komentářů: 0
    Kdo vám letos nadělí dárek?
     (34%)
     (2%)
     (11%)
     (2%)
     (1%)
     (2%)
     (16%)
     (18%)
     (13%)
    Celkem 93 hlasů
     Komentářů: 18, poslední 24.12. 15:29
    Rozcestník

    Administrace komentářů

    Jste na stránce určené pro řešení chyb a problémů týkajících se diskusí a komentářů. Můžete zde našim administrátorům reportovat špatně zařazenou či duplicitní diskusi, vulgární či osočující příspěvek a podobně. Děkujeme vám za vaši pomoc, více očí více vidí, společně můžeme udržet vysokou kvalitu AbcLinuxu.cz.

    Příspěvek
    13.3.2010 09:51 Radovan
    Rozbalit Rozbalit vše Re: Bankomat-Pascal
    To chceš říct že sis s tím po měsíci zase zkusil pohrát, a ono to pořád nefunguje? :-( A s tím formátováním bys také měl něco udělat, tohle rozluštit byla takhle po ránu fakt dřina! Za trest si to budeš muset přeložit z Céčka, protože Pascal už jsem fakt skoro zapomněl... Jen mi není jasné, proč stále trváš na té rekurzi, když se to dá řešit mnohem jednodušeji (je to sice prasárna, ale doufám že názorná):
    #include<stdio.h>
    
    int mince[6]={50,20,10,5,2,1};
    
    int main(void)
    {
        int i,j,k,l,m,n,castka=100,pocet=0;
    
        for(i=castka/mince[0];i>=0;--i)
            for(j=(castka-i*mince[0])/mince[1];j>=0;--j)
                for(k=(castka-i*mince[0]-j*mince[1])/mince[2];k>=0;--k)
                    for(l=(castka-i*mince[0]-j*mince[1]-k*mince[2])/mince[3];l>=0;--l)
                        for(m=(castka-i*mince[0]-j*mince[1]-k*mince[2]-l*mince[3])/mince[4];m>=0;--m)
                        {
                            n=(castka-i*mince[0]-j*mince[1]-k*mince[2]-l*mince[3]-m*mince[4])/mince[5];
                            printf("%d,%d,%d,%d,%d,%d,\n",i,j,k,l,m,n);
    
                            ++pocet;
                        }
        printf("kombinací: %d\n",pocet);
    
        return 0;
    }
    
    Značka { znamená begin, } end. No, sice jsi se s tím nepochlubil, ale předpokládám že rekurze byla součástí zadání, tak jsem vzal ten tvůj prográmek a pokusil se ho rozchodit. Máš štěstí že už jsi se blížil řešení, takže tady je výsledek:
    #include <stdio.h>
    
    int castka=100,    /* Na co jí tu máš, když jí v programu nepoužiješ? */
        platidla[7]={0,50,20,10,5,2,1},
        seznam[7],     /* [7] znamená v C array [0..6], 0 je nevyužitá. */
        pocet=0;       /* Při ladění se ti hodí vědět kolik kombinací vypočítal. */
    
    void rozmen(zbyvCastka,poslCastka)
    {
        int i,j;
    
        if(zbyvCastka==0)
        {
            for(i=1;i<=6;++i)
                printf("%d,",seznam[i]);
            putchar('\n');
            ++pocet;    /* ++ je obdoba příkazu inc, -- zase dec. */
        }
        else
        {
            if(poslCastka<=5)    /* Tohle je zbytečné, for si to přece ošetří. */
                for(i=(poslCastka+1);i<=6;++i)
                {
                    for(j=1;j<=(zbyvCastka/platidla[i]);++j)
                    /************************************************************
                     * Tady byla první chyba, řekni mi jeden rozumný důvod proč *
                     * tahle smyčka začínala od 0, od neexistujícího platidla!  *
                     * Tím se ti počet kombinací zvýšil z 4562 na 20875.        *
                     ************************************************************/
                    {
                        seznam[i]=j;
                        rozmen(zbyvCastka-j*platidla[i],i);
                    }
                    seznam[i]=0;
                    /*************************************************************
                     * Tady byla druhá chyba, protože sis po sobě před přechodem *
                     * na menší platidlo "neuklidil", tak ti u vyššího platidla  *
                     * zůstal předchozí maximální počet napočítaný smyčkou j!    *
                     * Tím by ti na konci vyšla kombinace 2,5,10,20,50,100,      *
                     *************************************************************/
                }
        }
    }
    
    int main(void)
    {
        int a;
    
        printf("Seznam castek v poradi 50,20,10,5,2,1\n");
        for(a=1;a<=6;++a)
            seznam[a]=0;
        rozmen(100,0);    /* Nechtěl jsi tady použít tu konstantu castka? */
        printf("kombinaci: %d\n",pocet);
        getchar();
    
        return 0;
    }
    
    Když ladíš program a nevíš přesně co bude provádět, zkus ho nejdřív pustit na nejjednodušší možnost, v tomhle případě mu dej rozměnit 1 korunu. Ten tvůj díky té první chybě vypsal dvaatřicet stejných řešení místo jednoho!

    Pokud bys chtěl rekurzi lépe pochopit, zkus si nějaký čas hrát s Karlem, kde si jí můžeš opravdu zviditelnit. Jednoduché pravidlo: Karel musí při návratu stát otočený do stejného směru, jako při vstupu do ní! To byla ta druhá chyba.

    Jedno mi ale slib, pokud by ses tímhle stylem třeba jednou měl živit jako programátor, najdi si práci v Microsoftu ;-)

    V tomto formuláři můžete formulovat svou stížnost ohledně příspěvku. Nejprve vyberte typ akce, kterou navrhujete provést s diskusí či příspěvkem. Potom do textového pole napište důvody, proč by měli admini provést vaši žádost, problém nemusí být patrný na první pohled. Odkaz na příspěvek bude přidán automaticky.

    Vaše jméno
    Váš email
    Typ požadavku
    Slovní popis
    ISSN 1214-1267   www.czech-server.cz
    © 1999-2015 Nitemedia s. r. o. Všechna práva vyhrazena.