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 04:22 | Nová verze

    Byla vydána nová verze 9.5 multiplatformní digitální pracovní stanice pro práci s audiem (DAW) Ardour. Přehled novinek, vylepšení a oprav v poznámkách k vydání a na YouTube.

    Ladislav Hagara | Komentářů: 0
    včera 21:00 | IT novinky

    Dnes a zítra probíhá vývojářská konference Google I/O 2026. Sledovat lze na YouTube a na síti 𝕏 (#GoogleIO).

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

    Canonical vydal Ubuntu Core 26. Vychází z Ubuntu 26.04 LTS a podporováno bude 15 let. Ubuntu Core je minimální neměnný operační systém určený pro vestavěné systémy.

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

    Bylo vydáno OpenBSD 7.9. Po dlouhé době opět se songem: Diamond in the Rough.

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

    Byl vydán Mozilla Firefox 151.0. Přehled novinek v poznámkách k vydání a poznámkách k vydání pro vývojáře. Řešeny jsou rovněž bezpečnostní chyby. Nový Firefox 151 bude brzy k dispozici také na Flathubu a Snapcraftu.

    Ladislav Hagara | Komentářů: 0
    včera 12:22 | IT novinky

    Elon Musk prohrál soudní spor se společností OpenAI, která se podle jeho žaloby odchýlila od původně uváděného cíle vyvíjet umělou inteligenci (AI) ku prospěchu lidstva. Porota včera po necelých dvou hodinách dospěla k jednomyslnému závěru, že Musk žalobu podal příliš pozdě. Musk byl jedním ze spoluzakladatelů společnosti OpenAI, která vznikla v roce 2015 a vyvinula populární chatovací systém ChatGPT. V roce 2018 na svůj post ve vedení

    … více »
    Ladislav Hagara | Komentářů: 0
    včera 10:22 | Nová verze

    Byla vydána nová verze 10.4 z Debianu vycházející linuxové distribuce DietPi pro (nejenom) jednodeskové počítače. Přehled novinek v poznámkách k vydání. Opraveny jsou zranitelnosti Copy Fail a Dirty Frag. Přibyl nový obraz pro Orange Pi 5B.

    Ladislav Hagara | Komentářů: 0
    včera 07:44 | Zajímavý software

    Pokud je zranitelnost Linuxu v nepoužívaném jaderném modulu, lze ji jednoduše vyřešit zakázáním automatického načítání tohoto konkrétního zranitelného modulu. Projekt ModuleJail si klade za cíl zvýšit bezpečnost Linuxu zakázáním automatického načítání všech nepoužívaných jaderných modulů. Jedná se o skript, který dá všechny nepoužívané jaderné moduly na blacklist (/etc/modprobe.d/modulejail-blacklist.conf).

    Ladislav Hagara | Komentářů: 1
    18.5. 16:11 | Zajímavý článek

    Odborníci z Penn State University zkoumají způsob ukládání informací na lepicí pásku. Principiálně by podle nich bylo možné kombinací odlepení a zpětného přilepení dosáhnout uložení informace, kterou opětovným odlepením dokážou přečíst. Výhodou je, že způsob uložení i přečtení je čistě mechanický. Zde o tom referují ve volně dostupném článku. Zajímavé bude sledovat zda se jim v rámci výzkumu podaří prokázat použitelnost i v jiné než

    … více »
    karkar | Komentářů: 10
    18.5. 13:00 | Zajímavý projekt

    Na GitHubu byl publikován reprodukovatelný návod, jak rozchodit Adobe Lightroom CC na Linuxu a Wine. Návod byl vytvořený pomocí AI Claude Code.

    Ladislav Hagara | Komentářů: 0
    Které desktopové prostředí na Linuxu používáte?
     (13%)
     (8%)
     (2%)
     (14%)
     (31%)
     (4%)
     (6%)
     (3%)
     (16%)
     (26%)
    Celkem 1669 hlasů
     Komentářů: 30, poslední 3.4. 20:20
    Rozcestník

    Dotaz: FOR cyklus v CECKU

    26.3.2009 11:48 Nicoolas_Doe
    FOR cyklus v CECKU
    Přečteno: 483×
    Muze mi nekdo vysvetlit, proc mi blbne forcyklus v nasledujici funkci? Funkce má vypsat na obrazovku nejdelsi pravy palindrom. Pr.: pro slovo "abcana", ma nejdelsi pravy palindrom je "ana" (pointer je 3). Funkce palindrom(char *text) vraci 0, pokud je retezec palindrom, jinak vraci 1. Pokud napisi funkci jak je o par radku niz, tak vsechno funguje jak chci. Ale pokud umazu rádek printf("Zkusebni vypis %s.\n",&text[i]); (kterej vubec nechci), tak je vysledek "a" (pointer je 5)

    int pravyPalindrom(char *text) { int i,pointer; for(i = 0; text[i] != '\0'; i++) { printf("Zkusebni vypis %s.\n",&text[i]); if (palindrom(&text[i]) == 0) { pointer = i; break; } } printf("Nejdelsi pravy palindrom je %s.\n",&text[pointer]);

    return (0); }

    Odpovědi

    26.3.2009 12:20 volca
    Rozbalit Rozbalit vše Re: FOR cyklus v CECKU

    Nevidim jinou moznost nez je chyba ve funkci palindrom. Ten zminovany kousek kodu s mym doplnenim chodi

    26.3.2009 12:26 Nicoolas_Doe
    Rozbalit Rozbalit vše Re: FOR cyklus v CECKU
    Ta funkce me funguje spravne. Jde ti to i bez toho radku s tim printf("Zkusebni vypis %s.\n",&text[i]); ?

    /*Funkce pro testovani, zda je retezec, prefiltrovany funkci isalpha, palindrom. Pokud je retezec patricny palindrom, funkce vraci 0, jinak 1.*/

    int palindrom(char *text) { int i,del; int delka = strlen(text); //delka vstupniho retezce char retez[delka]; //promenna pro prefiltrovany vstupni retezec /*Prefiltruje vstupni retezec funkci isalpha a vysledek ulozi do promenne retezec*/ for(i = 0; text[i] != '\0'; i++) { if (isalpha((int)text[i])) { del = strlen(retez); retez[del]=text[i]; retez[del+1]=0; } } /*Zjistuje, zda retez je palindrom */ for(i = 0; i != (strlen(retez)/2); i++) { if (retez[i] != retez[strlen(retez) -1 - i]) return(1); }

    return (0); }
    26.3.2009 12:33 volca
    Rozbalit Rozbalit vše Re: FOR cyklus v CECKU

    Chodi to bez toho filtru?

     

    Kam ukazuje "retez"? Asi by bylo vhodne ho pokazde alespon zinicializovat retez[0] = '\0'; Takhle to chodit nebude, bo tam bude odpad odminula

    26.3.2009 12:49 volca
    Rozbalit Rozbalit vše Re: FOR cyklus v CECKU

    A uz vidim - jak to neni formatovane ztratil se v komentari. Promene vzdy pred pouzitim inicializuj, jinak nevis s cim mas tu cest.

    26.3.2009 12:27 Nicoolas_Doe
    Rozbalit Rozbalit vše Re: FOR cyklus v CECKU
    Sorry za to radkovani...
    26.3.2009 13:07 Nicoolas_Doe
    Rozbalit Rozbalit vše Re: FOR cyklus v CECKU
    Příloha:
    Zkusil jsem vykuchat z celyho kodu vsechno zbytecny,takze to ted mozna bude vypadat, ze je to k nicemu. Ale jde mi o to, aby se na vystup vypsalo "Nejdelsi pravy palindrom je ana."
    26.3.2009 13:10 volca
    Rozbalit Rozbalit vše Re: FOR cyklus v CECKU

    zopakuju to jeste jednou :)

     

    Promene vzdy pred pouzitim inicializuj, jinak nevis s cim mas tu cest.

     

    proste, a sproste:

    char retez[delka];

    retez[0] = '\0';

    26.3.2009 13:15 Nicoolas_Doe
    Rozbalit Rozbalit vše Re: FOR cyklus v CECKU
    To nepomohlo:(
    26.3.2009 13:18 Nicoolas_Doe
    Rozbalit Rozbalit vše Re: FOR cyklus v CECKU
    Tak promin, pomohlo...Mel jsi pravdu, chyba ve funkci palindrom. Moc dekuji za pomoc.
    26.3.2009 13:22 volca
    Rozbalit Rozbalit vše Re: FOR cyklus v CECKU

    Nejni zac :)

     

    Jinak vysvetleni je proste - to pole bylo alokovano na stacku (coz nerozhoduje, ono malloc by to udelal stejne). Stack se necisti pri vytvareni promennych, protoze je to drahe (a jazyk obecne nemuze tusit co za hodnotu autor zamyslel mit v te promenne jako vychozi). Pomocny printf tam na stack zrejme zapisoval nulu, coz !nahodou! zpusobilo ze to pracovalo. Tohle je rek bych tipicka ukazka chyby kterou (kdyby to nahodou fungovalo vzdy, a nebyla by odhalena) by nekdo mohl exploitem zneuzit.

     

    Valgrind by tuhle chybu odhalil, doporucuju ho nastudovat a vyzkouset.

    26.3.2009 13:26 Sinuhet | skóre: 31
    Rozbalit Rozbalit vše Re: FOR cyklus v CECKU
    Příloha:
    Ono tam toho bylo vic...
    26.3.2009 13:50 Nicoolas_Doe
    Rozbalit Rozbalit vše Re: FOR cyklus v CECKU
    Myslis vic chyb? K cemu je ten Valgrind?
    27.3.2009 08:48 volca
    Rozbalit Rozbalit vše Re: FOR cyklus v CECKU

    Vsak si srovnej jeho verzi s tou svoji :)

     

    Valgrind je nastroj na (mimo jine) sledovani chyb prace s pameti - odhali ze kod pracuje s neinicializovanou pameti, uvolnenou pameti, mimo rozsah dany alokaci, atd.

    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.