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 12:22 | Nová verze Ladislav Hagara | Komentářů: 0
    včera 20:00 | Komunita

    Byly zpracovány a na YouTube zveřejněny videozáznamy z konference LinuxDays 2025.

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

    Na konferenci LinuxDays 2025 byl oficiálně představen nový router Turris Omnia NG.

    Ladislav Hagara | Komentářů: 26
    4.10. 05:22 | Komunita

    Přímý přenos (YouTube) z konference LinuxDays 2025, jež probíhá tento víkend v Praze v prostorách FIT ČVUT. Na programu je spousta zajímavých přednášek.

    Ladislav Hagara | Komentářů: 12
    3.10. 22:44 | IT novinky

    V únoru loňského roku Úřad pro ochranu osobních údajů pravomocně uložil společnosti Avast Software pokutu 351 mil. Kč za porušení GDPR. Městský soud v Praze tuto pokutu na úterním jednání zrušil. Potvrdil ale, že společnost Avast porušila zákon, když skrze svůj zdarma dostupný antivirový program sledovala, které weby jeho uživatelé navštěvují, a tyto informace předávala dceřiné společnosti Jumpshot. Úřad pro ochranu osobních údajů

    … více »
    Ladislav Hagara | Komentářů: 6
    3.10. 19:00 | Nová verze

    Google Chrome 141 byl prohlášen za stabilní. Nejnovější stabilní verze 141.0.7390.54 přináší řadu novinek z hlediska uživatelů i vývojářů. Podrobný přehled v poznámkách k vydání. Opraveno bylo 21 bezpečnostních chyb. Za nejvážnější z nich (Heap buffer overflow in WebGPU) bylo vyplaceno 25 000 dolarů. Vylepšeny byly také nástroje pro vývojáře.

    Ladislav Hagara | Komentářů: 0
    3.10. 17:11 | Upozornění

    eDoklady mají kvůli vysoké zátěži technické potíže. Ministerstvo vnitra doporučuje vzít si sebou klasický občanský průkaz nebo pas.

    Ladislav Hagara | Komentářů: 25
    3.10. 17:00 | Komunita

    Novým prezidentem Free Software Foundation (FSF) se stal Ian Kelling.

    Ladislav Hagara | Komentářů: 1
    3.10. 14:33 | Komunita

    Na čem pracují vývojáři webového prohlížeče Ladybird (GitHub)? Byl publikován přehled vývoje za září (YouTube).

    Ladislav Hagara | Komentářů: 0
    3.10. 12:33 | Upozornění

    Vyšla kniha Počítačové programy a autorské právo. Podle internetových stránek nakladatelství je v knize "Významný prostor věnován otevřenému a svobodnému softwaru, jeho licencím, důsledkům jejich porušení a rizikům „nakažení“ proprietárního kódu režimem open source."

    javokajifeng | Komentářů: 0
    Jaké řešení používáte k vývoji / práci?
     (38%)
     (45%)
     (16%)
     (18%)
     (21%)
     (15%)
     (18%)
     (16%)
     (16%)
    Celkem 177 hlasů
     Komentářů: 12, poslední 4.10. 20:35
    Rozcestník

    Dotaz: c++ sifrovani

    12.4.2013 21:00 marek33
    c++ sifrovani
    Přečteno: 836×
    ahoj, muzete mi nekdo prosim vysvetlit co dela tucne napsana cast programu

    int main(){
     FILE *f,*g;
     int znak;
     int pocet=0,a,b,c;
     printf("Zadejte tri cisla pro sifrovani: ");
     scanf("%d %d %d",&a,&b,&c);
     f=fopen("original.txt","r");
     g=fopen("sifra.txt","w");
     while((znak=getc(f))!=EOF){
       switch(pocet%3){
         case 0:znak=znak+a; break;
         case 1:znak=znak+b; break;
         case 2:znak=znak+c; break;              
       }
     if (znak>255)
         znak=znak-256;
       putc(znak,g);
       pocet++;                          
     }
     fclose(f);
     fclose(g);
     getchar();
     getchar();   
     return 0;   
    }

    Řešení dotazu:


    Odpovědi

    12.4.2013 21:10 potato
    Rozbalit Rozbalit vše Re: c++ sifrovani
    Vypíše jeden znak do souboru g. Pokud je kód znaku větší než 256 (protože je to výsledek jakéhosi sčítání), tak nejdřív odečte 256.

    Což je tedy doslovné převyprávění toho kódu, ale nic záhadného v něm není, takže nic jiného jsi ani moc čekat nemohl...
    Řešení 1× (mimi.vx)
    rADOn avatar 15.4.2013 14:58 rADOn | skóre: 44 | blog: bloK | Praha
    Rozbalit Rozbalit vše Re: c++ sifrovani
    Je to naivni implementace vigenerovy sifry pro hardcodovany pocet abeced (tri). Sifrovani probiha v modulo-N aritmetice kde N je delka abecedy. V tomto pripade 256 (velikost charu), a protoze autor toho kodu evidentne nevedel ze mod-256 aritmetiku lze v C dosahnout prostym pretypovanim na char, udelal tu osklivost s odecitanim 256. pocet++ zajistuje prohazovani sifrovacich abeced.

    BTW doufam ze nemas v umyslu to nejak pouzivat, jako sifra to nestoji za moc a jako programovani v C je to na zastreleni.
    "2^24 comments ought to be enough for anyone" -- CmdrTaco
    15.4.2013 16:26 kuka
    Rozbalit Rozbalit vše Re: c++ sifrovani
    Zminene pretypovani dela sama putc, takze v programu nemusi byt nic. Jsem liny to zkouset, ale kdyz znak == EOF, coz nastane pro prazdny vstupni soubor, tak bych asi cekal, ze to spadne.

    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.