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 13:11 | Nová verze

    Svobodná webová platforma pro sdílení a přehrávání videí PeerTube (Wikipedie) byla vydána v nové verzi 6.1. Přehled novinek i s náhledy v oficiálním oznámení a na GitHubu. Řešeny jsou také 2 bezpečnostní chyby.

    Ladislav Hagara | Komentářů: 0
    dnes 12:33 | Zajímavý software

    Lennart Poettering na Mastodonu představil utilitu run0. Jedná se o alternativu k příkazu sudo založenou na systemd. Bude součástí systemd verze 256.

    Ladislav Hagara | Komentářů: 4
    včera 23:22 | Nová verze

    Hudební přehrávač Amarok byl vydán v nové major verzi 3.0 postavené na Qt5/KDE Frameworks 5. Předchozí verze 2.9.0 vyšla před 6 lety a byla postavená na Qt4. Portace Amaroku na Qt6/KDE Frameworks 6 by měla začít v následujících měsících.

    Ladislav Hagara | Komentářů: 7
    včera 21:44 | Komunita

    Ubuntu 24.10 bude Oracular Oriole (věštecká žluva).

    Ladislav Hagara | Komentářů: 10
    včera 20:22 | Nová verze

    Byla vydána nová verze 2.45.0 distribuovaného systému správy verzí Git. Přispělo 96 vývojářů, z toho 38 nových. Přehled novinek v příspěvku na blogu GitHubu a v poznámkách k vydání. Vypíchnout lze počáteční podporu repozitářů, ve kterých lze používat SHA-1 i SHA-256.

    Ladislav Hagara | Komentářů: 0
    včera 13:33 | IT novinky

    Před 25 lety, ve čtvrtek 29. dubna 1999, byla spuštěna služba "Úschovna".

    Ladislav Hagara | Komentářů: 0
    včera 01:00 | Nová verze

    Byla vydána nová verze 24.04.28 s kódovým názvem Time After Time svobodného multiplatformního video editoru Shotcut (Wikipedie) a nová verze 7.24.0 souvisejícího frameworku MLT Multimedia Framework. Nejnovější Shotcut je vedle zdrojových kódů k dispozici také ve formátech AppImage, Flatpak a Snap.

    Ladislav Hagara | Komentářů: 0
    28.4. 16:33 | Nová verze Ladislav Hagara | Komentářů: 0
    28.4. 03:22 | Zajímavý článek

    V aktuálním příspěvku na blogu počítačové hry Factorio (Wikipedie) se vývojář s přezývkou raiguard rozepsal o podpoře Linuxu. Rozebírá problémy a výzvy jako přechod linuxových distribucí z X11 na Wayland, dekorace oken na straně klienta a GNOME, změna velikosti okna ve správci oken Sway, …

    Ladislav Hagara | Komentářů: 0
    28.4. 00:11 | Nová verze

    Rakudo (Wikipedie), tj. překladač programovacího jazyka Raku (Wikipedie), byl vydán ve verzi #171 (2024.04). Programovací jazyk Raku byl dříve znám pod názvem Perl 6.

    Ladislav Hagara | Komentářů: 7
    KDE Plasma 6
     (75%)
     (8%)
     (2%)
     (15%)
    Celkem 884 hlasů
     Komentářů: 4, poslední 6.4. 15:51
    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.