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

    Google představil platformu Code Wiki pro rychlejší porozumění existujícímu kódu. Code Wiki pomocí AI Gemini udržuje průběžně aktualizovanou strukturovanou wiki pro softwarové repozitáře. Zatím jenom pro veřejné. V plánu je rozšíření Gemini CLI také pro soukromé a interní repozitáře.

    Ladislav Hagara | Komentářů: 1
    včera 14:22 | Bezpečnostní upozornění

    V přihlašovací obrazovce LightDM KDE (lightdm-kde-greeter) byla nalezena a již opravena eskalace práv (CVE-2025-62876). Detaily v příspěvku na blogu SUSE Security.

    Ladislav Hagara | Komentářů: 5
    včera 13:22 | Nová verze

    Byla vydána nová verze 7.2 živé linuxové distribuce Tails (The Amnesic Incognito Live System), jež klade důraz na ochranu soukromí uživatelů a anonymitu. Tor Browser byl povýšen na verzi 15.0.1. Další novinky v příslušném seznamu.

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

    Česká národní banka (ČNB) nakoupila digitální aktiva založená na blockchainu za milion dolarů (20,9 milionu korun). Na vytvořeném testovacím portfoliu, jehož součástí jsou bitcoin, stablecoiny navázané na dolar a tokenizované depozitum, chce získat praktickou zkušenost s držením digitálních aktiv. Portfolio nebude součástí devizových rezerv, uvedla dnes ČNB v tiskové zprávě.

    Ladislav Hagara | Komentářů: 40
    včera 03:22 | IT novinky

    Apple představil iPhone Pocket pro stylové přenášení iPhonu. iPhone Pocket vzešel ze spolupráce značky ISSEY MIYAKE a Applu a jeho tělo tvoří jednolitý 3D úplet, který uschová všechny modely iPhonu. iPhone Pocket s krátkým popruhem se prodává za 149,95 dolarů (USA) a s dlouhým popruhem za 229,95 dolarů (USA).

    Ladislav Hagara | Komentářů: 17
    včera 02:33 | Nová verze

    Byla vydána nová stabilní verze 7.7 webového prohlížeče Vivaldi (Wikipedie). Postavena je na Chromiu 142. Přehled novinek i s náhledy v příspěvku na blogu.

    Ladislav Hagara | Komentářů: 0
    13.11. 22:11 | Nová verze

    Společnost Epic Games vydala verzi 5.7 svého proprietárního multiplatformního herního enginu Unreal Engine (Wikipedie). Podrobný přehled novinek v poznámkách k vydání.

    Ladislav Hagara | Komentářů: 2
    13.11. 16:22 | Bezpečnostní upozornění

    Intel vydal 30 upozornění na bezpečnostní chyby ve svých produktech. Současně vydal verzi 20251111 mikrokódů pro své procesory.

    Ladislav Hagara | Komentářů: 0
    13.11. 15:33 | Nová verze

    Byla vydána říjnová aktualizace aneb nová verze 1.106 editoru zdrojových kódů Visual Studio Code (Wikipedie). Přehled novinek i s náhledy a videi v poznámkách k vydání. Ve verzi 1.106 vyjde také VSCodium, tj. komunitní sestavení Visual Studia Code bez telemetrie a licenčních podmínek Microsoftu.

    Ladislav Hagara | Komentářů: 1
    13.11. 12:11 | Komunita

    Canonical pro své zákazníky, předplatitele Ubuntu Pro, prodloužil podporu Ubuntu LTS z 12 let na 15 let (Legacy add-on). Týká se verzí od 14.04 (Trusty Tahr).

    Ladislav Hagara | Komentářů: 2
    Jaké řešení používáte k vývoji / práci?
     (35%)
     (47%)
     (18%)
     (18%)
     (23%)
     (15%)
     (22%)
     (15%)
     (16%)
    Celkem 353 hlasů
     Komentářů: 16, poslední 12.11. 18:21
    Rozcestník

    Dotaz: JAVA - "šifrování" textu

    martidlo avatar 10.11.2009 14:44 martidlo | skóre: 3 | blog: Vztekárna | Opava
    JAVA - "šifrování" textu
    Přečteno: 1398×
    Ahoj, trochu víc jsem se zasekla při mém úkolu do programování.

    Zadání úkolu: Vytvořte třídu, která bude mít dvě metody, které budou sloužit pro překlad textu do a z "obráceného jazyka". Základ třídy může vypadat např. takto: Metoda pro obracení bude fungovat tak, že pořadí slov ve větě zůstane zachováno, všechna písmena slova budou v opačném pořadí. Například tedy z věty "Včera jsem programoval." bude přoložena takto "arečv mesj lavomargorp." Správnost fungování obou metod ověříte pomocí testovací třídy.

    Nevíte někdo, jak na to? Děkuju za každou radu, Martina.

    Řešení dotazu:


    Odpovědi

    10.11.2009 15:11 razor | skóre: 33
    Rozbalit Rozbalit vše Re: JAVA - "šifrování" textu
    No třeba tak, že rozsekáš [split] text pomocí regulárního výrazu [whitespace] na jednotlivá slova, čímž ti vznikne nějaký seznam slov. Slova v tomto seznamu pak obrátíš [reverse] a z těchto sestrojíš větu. Komplikovanejší by to bylo, kdyby si musela zachovat stejné oddělovače slov. Musela by si zřejmě někde držet ještě seznam, kde by byly jednotlivé oddělovače slov.
    default avatar 10.11.2009 16:53 default | skóre: 22 | Madrid
    Rozbalit Rozbalit vše Re: JAVA - "šifrování" textu

    To samo o sobě nestačí. Vždyť jen pozice tečky v příkladu:

    arečv mesj lavomargorp.
    

    Chce to doplnit zadání. I tak to na mě dělá dojem, že ta rutina má převádět do malých písmen — viz počáteční písmenko věty. Pak to ale nebude pracovat obousměrně. Buď je špatně specifikace, nebo příklad. S tímhle materiálem se prostě nedá dělat…

    10.11.2009 17:08 razor | skóre: 33
    Rozbalit Rozbalit vše Re: JAVA - "šifrování" textu
    Ajo, ty tečky jsem si nevšim ...
    10.11.2009 17:14 l4m4
    Rozbalit Rozbalit vše Re: JAVA - "šifrování" textu
    Řešení pro libovolný programovací jazyk, kde lze použít reguálrní výrazy (a které zaručeně rozhodí zadávájícího):

    1. Na konce slov dopiš značku (předpokládám #), tj. ekvivalent
    s/\>/#/g
    
    2. Dokud je úspěšné (tj. provede se nenulový počet nahrazení), posunuj znak před značkou, kam patří, tj. ekvivalent:
    s/(\w*)(\w)#(\w*)/\1#\3\2/g
    
    3. Odstraň značky:
    s/#//g
    
    Konkrétní tvar regulárních výrazů se trochu liší podle jazyka a nahrazení se bude dělat nějakou funkcí/metodou, ale lze to takto udělat v čemkoli od sedu přes C po Javu.
    martidlo avatar 10.11.2009 17:48 martidlo | skóre: 3 | blog: Vztekárna | Opava
    Rozbalit Rozbalit vše Re: JAVA - "šifrování" textu
    Tak to je i na mě trošku moc... asi jsem blbá...
    martidlo avatar 10.11.2009 17:15 martidlo | skóre: 3 | blog: Vztekárna | Opava
    Rozbalit Rozbalit vše Re: JAVA - "šifrování" textu
    Nedá no, to vím sama... :-(
    Řešení 1× (kouby)
    10.11.2009 18:09 Michal
    Rozbalit Rozbalit vše Re: JAVA - "šifrování" textu

    Podivej se na tridu StringBuilder ze zakladniho baliku java.lang - jeji popis nades v JDKcku. Ta obsahuje metodu Reverse(). Coz by melo prakticky byt co hledas, jen to spravne pouzit ... ;-). Navic je Stringbuilder optimalnim resenim - v pripade velkeho mnozstvi casto se menicich retezcu nebudes vytvaret stale nove instance, jako by tomu bylo v pripade Stringu.

    10.11.2009 21:39 Noname
    Rozbalit Rozbalit vše Re: JAVA - "šifrování" textu
    Plus pre jednoduche rozdelenie na slova by islo pouzit java.util.StringTokenizer
    Milan Lajtoš avatar 10.11.2009 23:50 Milan Lajtoš | skóre: 22 | blog: /blog/babraq
    Rozbalit Rozbalit vše Re: JAVA - "šifrování" textu
    
    public static String sifruj(String s){
    	StringTokenizer st = new StringTokenizer(s, " .:!?", true);
    	String result = "";
    	
    	while (st.hasMoreTokens()){
    		result += (new StringBuilder(st.nextToken())).reverse();
    	}
    	
    	return result;
    }
    
    “Every great achievement was once considered impossible.”
    10.11.2009 18:16 ::: | skóre: 14 | blog: e_lama
    Rozbalit Rozbalit vše Re: JAVA - "šifrování" textu
    reseni v perlu. prepsat to do javy by nemel byt problem:
    $x = "Vcera jsem programoval.";
    $r = "";
    while ($x =~ m/^([^A-Za-z]*)([A-Za-z]+)(.*)$/)
    {
            $r .= $1 . reverse($2);
            $x = $3;
    }
    $r .= $x;
    
    print "$r\n";
    
    10.11.2009 19:39 l4m4
    Rozbalit Rozbalit vše Re: JAVA - "šifrování" textu
    Perl má u operátoru s/// volbu e. K čemu asi?

    I když zda může být v Jave nahrazení regulárního výrazu metoda, to nevím...
    10.11.2009 20:53 ::: | skóre: 14 | blog: e_lama
    Rozbalit Rozbalit vše Re: JAVA - "šifrování" textu
    volba e v tomhle pripade pouzit nejde (nebo me ted aspon nenapada jak)

    zkus si spustit treba:
    $x = "Vcera jsem programoval.";
    while ($x =~ s/^([^A-Za-z]*)([A-Za-z]+)(.*)$/$1 . reverse($2) . $3/e)
    {
            print "$x\n";
    }
    
    vysledek
    Vcera jsem programoval.
    arecV jsem programoval.
    Vcera jsem programoval.
    ...
    
    ale hlavni duvod proc jsem pouzil jenom m// je ze nevim na jaky urovni jsou RE v jave tak jsem to nechtel zbytecne komplikovat...
    10.11.2009 20:59 ::: | skóre: 14 | blog: e_lama
    Rozbalit Rozbalit vše Re: JAVA - "šifrování" textu
    sorry, jde to pouzit. Ja jdu dneska uz radis spat...
    $x = "Vcera jsem programoval.";
    $x =~ s/([A-Za-z]+)/reverse($1)/ge;
    print "$x";
    Milan Lajtoš avatar 10.11.2009 21:19 Milan Lajtoš | skóre: 22 | blog: /blog/babraq
    Rozbalit Rozbalit vše Re: JAVA - "šifrování" textu
    Je to triviálna úloha, stačí trochu porozmýľať.
    
    
    String novy_retazec = "";
    String slovo;
    
    [kym nie som na konci retazca]
      slovo = "";
      [kym nenarazim na koniec slova] //napr. medzera
        slovo = [aktualne pismeno] + slovo;
    
      novy_retazec += " " + slovo;
    
    
    Alebo na prevracanie stringov použiť StringBuilder
    “Every great achievement was once considered impossible.”

    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.