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:11 | IT novinky

    Rusko zcela zablokovalo komunikační platformu WhatsApp, řekl včera mluvčí Kremlu Dmitrij Peskov. Aplikace, jejímž vlastníkem je americká společnost Meta Platforms a která má v Rusku na 100 milionů uživatelů, podle Peskova nedodržovala ruské zákony. Mluvčí zároveň lidem v Rusku doporučil, aby začali používat domácí aplikaci MAX. Kritici tvrdí, že tato aplikace ruské vládě umožňuje lidi sledovat, což úřady popírají.

    Ladislav Hagara | Komentářů: 0
    dnes 11:44 | IT novinky

    Před 34 lety, ve čtvrtek 13. února 1992, se tehdejší Česká a Slovenská Federativní Republika oficiálně (a slavnostně) připojila k Internetu.

    Ladislav Hagara | Komentářů: 1
    dnes 04:44 | Humor

    Agent umělé inteligence vytvořil 'útočný' článek o Scottu Shambaughovi, dobrovolném správci knihovny matplotlib, poté, co vývojář odmítl agentem navrženou změnu kódu (pull request). 'Uražený' agent autonomně sepsal a publikoval na svém blogu článek, který přisuzuje Shambaughovi smyšlené motivace, egoismus a strach z AI coby konkurence.

    NUKE GAZA! 🎆 | Komentářů: 10
    včera 20:11 | Nová verze

    Bylo vydáno Ubuntu 24.04.4 LTS, tj. čtvrté opravné vydání Ubuntu 24.04 LTS s kódovým názvem Noble Numbat. Přehled novinek a oprav na Discourse.

    Ladislav Hagara | Komentářů: 0
    včera 17:44 | Pozvánky

    V pátek 20. února 2026 se v pražské kanceláři SUSE v Karlíně uskuteční 6. Mobile Linux Hackday, komunitní setkání zaměřené na Linux na mobilních zařízeních, kernelový vývoj a uživatelský prostor. Akce proběhne od 10:00 do večera. Hackday je určen všem, kteří si chtějí prakticky vyzkoušet práci s linuxovým jádrem i uživatelským prostorem, od posílání patchů například pomocí nástroje b4, přes balíčkování a Flatpak až po drobné úpravy

    … více »
    lkocman | Komentářů: 5
    včera 13:33 | IT novinky

    Evropská rada vydavatelů (EPC) předložila Evropské komisi stížnost na americkou internetovou společnost Google kvůli její službě AI Overviews (AI souhrny), která při vyhledávání na internetu zobrazuje shrnutí informací ze zpravodajských serverů vytvořená pomocí umělé inteligence (AI). Evropská komise již v prosinci oznámila, že v souvislosti s touto službou začala firmu Google vyšetřovat. Google obvinění ze strany vydavatelů

    … více »
    Ladislav Hagara | Komentářů: 12
    včera 04:44 | Komunita

    Ubuntu 26.04 (Resolute Raccoon) už nebude v desktopové instalaci obsahovat GUI nástroj 'Software & Updates'. Důvodem jsou obavy z jeho složitosti pro běžné uživatele a z toho plynoucích bezpečnostních rizik. Nástroj lze doinstalovat ručně (sudo apt install software-properties-gtk).

    NUKE GAZA! 🎆 | Komentářů: 25
    včera 04:33 | IT novinky

    Thomas Dohmke, bývalý CEO GitHubu, představil startup Entire - platformu pro spolupráci vývojářů a agentů umělé inteligence. Entire získalo rekordních 60 milionů dolarů na vývoj databáze a nástrojů, které mají zefektivnit spolupráci mezi lidmi a agenty umělé inteligence. Dohmke zdůrazňuje potřebu přepracovat tradiční vývojové postupy tak, aby odpovídaly realitě, kdy většinu kódu produkuje umělá inteligence.

    NUKE GAZA! 🎆 | Komentářů: 0
    včera 04:22 | Zajímavý projekt

    Toyota Connected North America oznámila vývoj open-source herního enginu Fluorite, postaveného na frameworku Flutter. Pro renderování grafiky využívá 3D engine Filament od společnosti Google a dle svého tvrzení cílí na konzolovou kvalitu her. Fluorite je zřejmě navržen tak, aby fungoval i na méně výkonném hardware, což naznačuje možnost použití přímo v ICE systémech vozidel. Zdrojový kód zatím zveřejněný není.

    NUKE GAZA! 🎆 | Komentářů: 4
    včera 04:11 | Bezpečnostní upozornění

    Byl vytvořen nástroj a postup pro překonání věkového ověření platforem Discord, Kick, Twitch, Snapchat (a možná dalších), kód je open-source a dostupný na GitHubu. Všechny tyto sítě používají stejnou službu k-ID, která určuje věk uživatele scanem obličeje a na původní server posílá pouze šifrovaná metadata, ty ale sociální síť už nedokáže sama nijak validovat, 'útok' spočívá ve vygenerování a podstrčení legitimně vypadajících ověřovacích metadat.

    NUKE GAZA! 🎆 | Komentářů: 13
    Které desktopové prostředí na Linuxu používáte?
     (19%)
     (6%)
     (0%)
     (11%)
     (26%)
     (3%)
     (4%)
     (2%)
     (12%)
     (27%)
    Celkem 858 hlasů
     Komentářů: 25, poslední 3.2. 19:50
    Rozcestník

    Dotaz: C - přístup ke jednotlivým znakům řetězce

    11.11.2009 11:19 Afill
    C - přístup ke jednotlivým znakům řetězce
    Přečteno: 981×

    Dobrý den, řeším jedem problém, který mi docela láme hlavu. Řekněme, že mám nějaký řetězec a chci jej předat jako parametr funkci, která vrátí stejně dlouhý řetězec s přeházenými písmeny. Jak na to? Když zkusím třeba:

    char *Fce(char *str)

    {

    char *newStr = str;

    newStr[1] = newStr[6]; // Zde je již chyba!

    printf("%c\n", newStr[1]);

    return newStr;

    }

    Jde o to, že jsem zkoušel všemožné kombinace, ale zkrátka jsem nepřišel na to, jak prohodit znaky u jiného řetězce než s předem definovanou délkou (např: "char str[10];").

    Byl by někdo tak laskav a napsal mi takovou funkci která přehodí některé znaky a vrátí upravený řetězec? Děkuji


    Řešení dotazu:


    Odpovědi

    11.11.2009 11:41 Atom321 | skóre: 20
    Rozbalit Rozbalit vše Základy
    Pane kolego, tudy cesta nevede. Pokud to má být pokus ofixlovat nějakou práci do školy, požádejte zkušenějšího kamaráda. Chcete-li opravdu programovat, musíte se to nejprve naučit.

    Dobrým začátkem s C je "Učebnice jazyka C" od P. Herouta. Ovšem vám by se ještě předtím hodila spíš nějaká středoškolská skripta o programování jako takovém.
    11.11.2009 11:54 Afill
    Rozbalit Rozbalit vše Re: Základy
    Děkuji za konstruktivní návrh, ale bohužel k řešení to nevede. Jsem zvyklý na jiné programovací jazyky, které mají práci s řetězci "jednodušší" a jsem si vědom, že mi některé základy z jazyka C unikají. Nicméně C příliš často nepoužívám. Samozřejmě jsem před položením dotazu hledal kde se dalo. Bohužel marně.

    Mimochodem nevím jak vy, ale pod pojmem "ofixlovat" si představuji něco opsat, ne něco pochopit.
    11.11.2009 14:55 Atom321 | skóre: 20
    Rozbalit Rozbalit vše Re: Základy
    Děkuji za konstruktivní návrh, ale bohužel k řešení to nevede.
    Ale vede. Jen delší cestou, než jste ochoten akceptovat.
    Samozřejmě jsem před položením dotazu hledal kde se dalo. Bohužel marně.
    To jste zřejmně minul tento článek: http://www.linuxsoft.cz/article.php?id_article=842
    Mimochodem nevím jak vy, ale pod pojmem "ofixlovat" si představuji něco opsat, ne něco pochopit.
    Ano, přesně tak. Pokud chcete pochopit, hotové řešení jedné konkrétní funkce vám stačit nebude.
    11.11.2009 12:15 Afill
    Rozbalit Rozbalit vše Re: C - přístup ke jednotlivým znakům řetězce
    Už jsem na to přišel. Vytvořil jsem nový řetězec a alokoval pro něj paměť novy = (char *) malloc(strlen(stary));

    Ještě se mi to někde ztrácí v paměti, ale na to snad už přijdu.
    11.11.2009 14:21 Atom321 | skóre: 20
    Rozbalit Rozbalit vše Re: C - přístup ke jednotlivým znakům řetězce
    Chyba. Řetězce v C jsou ukončeny nulou (znakem s kódem 0), který se do celkové délky nepočítá.

    Správně je tedy:
    novy = (char*) malloc(strlen(stary)+1); /* alokace stringu stejne velikosti */
    if (novy == NULL)
    {
       /* nahlasit chyby alokace */
    }
    strcpy(novy,stary);  /* zkopirovani puvodniho stringu do nove alokovane pameti */
    /* ... pouziti ... */
    
    free(novy); /* dealokace (uvolneni pameti) */
    
    Místo malloc a strcpy lze také použít strdup:
    novy = strdup(stary); /* alokace noveho stringu stejne velikosti a zkopirovani obsahu ze stareho */
    if (novy == NULL)
    {
       /* nahlasit chyby alokace */
    }
    
    /* ... pouziti ... */
    
    free(novy); /* dealokace (uvolneni pameti) */
    
    Funkce strdup() není součástí ANSI C, tedy nemusí být přenositelná na jiné systémy.
    11.11.2009 12:26 Marble | skóre: 27 | blog: marble
    Rozbalit Rozbalit vše Re: C - přístup ke jednotlivým znakům řetězce
    Ta funkce je IMO v pořádku. Teda záleží na tom, co přesně od ní čekáš. Pokud ji budeš volat s parametrem, který je odkazem do paměti na alokovaný string, tak fajn. Pokud ji ale budeš volat s konstantou (Fce("ABCDEFGHIJ");), tak skončí na tom, že se snaží měnit právě přímo svůj parametr.

    Přiřazení lokální proměnní na začátku totiž jen přiřadí ten pointer, tudíž je vlastně zbytečné. Předpokládám, že cheš ve funkci vytvořit kopii stringu a tu upravit. V tom případě se v čistém C nevyhneš mallocu nové paměti, do které ten string zkopíruješ (strcpy) a pak teprv budeš upravovat.

    Jo a ten, kdo tu funkci volal si pak samozřejmě musí alokovanou pamět uklidit. Funkce sama to z principu udělat nemůže.

    Druhým přiblížením, použitým v některých C knihovnách, je místo alokace paměti použít nějakou globální proměnnou deklarovanou v knihovně, ve které je i ona Fce (tahle proměnná nemusí být viditelná ven z knihovny). Fce si pak string zkopíruje do této proměnné. Výhodou je, že volající nemusí uklízet pamět, nevýhodou je, že po opětovném volání Fce je pamět přepsána a tudíž pointer vrácený dřívějším voláním bude odkazovat na "špatný" string. (Každé volání prostě vrátí stejný pointer.)

    11.11.2009 12:38 moira | skóre: 30 | blog: nesmysly
    Rozbalit Rozbalit vše Re: C - přístup ke jednotlivým znakům řetězce
    Je důvod proč nepoužít strrev?
    Překladač ti nikdy neřekne: "budeme kamarádi"
    20.11.2009 17:12 bajo | skóre: 3
    Rozbalit Rozbalit vše Re: C - přístup ke jednotlivým znakům řetězce
    jedine co tu potrebujes je troska pochopit ukazovatele. Vidiet za im nerozumies.
    20.11.2009 18:39 ext3fs
    Rozbalit Rozbalit vše Re: C - přístup ke jednotlivým znakům řetězce
    Pokud jde jen o prehozeni tak neco takoveho by mohlo fungovat:
    char *prehod(const char *str)
    {
    char *buff;
    int n, i = 0;
    
        if ((buff = (char *)malloc((strlen(str) + 1) * sizeof(char))) == NULL)
        {
            fprintf(stdout, "Chyba alokace.\n");
            exit (1);
        }
    
        for(n = strlen(str) - 1; n >= 0; n--)
            buff[i++] = str[n];
    
        buff[i] = '\0';
    
        return (buff);
    }
    
    int main(void)
    {
    char str[5];
    
        strcpy(str, "ahoj");
    
        fprintf(stdout, "%s\n", prehod(str));
    
        return (0);
    }
    
    

    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.