Ubuntu pro testování nových verzí vydává měsíční snapshoty. Dnes vyšel 1. snapshot Ubuntu 26.04 LTS (Resolute Raccoon).
Zástupci členských států EU se včera shodli na návrhu, který má bojovat proti šíření materiálů na internetu zobrazujících sexuální zneužívání dětí. Nařízení známé pod zkratkou CSAM a přezdívané chat control mělo množství kritiků a dlouho nebyla pro jeho schválení dostatečná podpora. Pro schválení byla potřeba kvalifikovaná většina a dánské předsednictví v Radě EU se snažilo dosáhnout kompromisu. Návrh nakonec po dlouhých týdnech
… více »Britské herní studio Facepunch stojící za počítačovými hrami Garry's Mod a Rust uvolnilo svůj herní engine s&box (Wikipedie) jako open source. Zdrojové kódy jsou k dispozici na GitHubu pod licencí MIT. Herní engine s&box je postavený nad proprietárním herním enginem Source 2 od společnosti Valve.
Vývoj programovacího jazyka Zig byl přesunut z GitHubu na Codeberg. Sponzoring na Every.
Stejně jako GNOME i KDE Plasma končí s X11. KDE Plasma 6.8 poběží už pouze nad Waylandem. Aplikace pro X11 budou využívat XWayland.
Poslanci Evropského parlamentu dnes vyzvali k výraznému zvýšení ochrany nezletilých na internetu, včetně zákazu vstupu na sociální sítě pro osoby mladší 16 let. Legislativně nezávazná zpráva, kterou dnes odsouhlasil Evropský parlament poměrem 493 hlasů pro ku 92 proti, kromě zavedení věkové hranice 16 let pro využívání sociálních sítí, platforem pro sdílení videí či společníků s umělou inteligencí (AI) vyzývá také k zákazu … více »
Doom v KiCadu nebo na osciloskopu? Žádný problém: KiDoom: Running DOOM on PCB Traces a ScopeDoom: DOOM on an Oscilloscope via Sound Card.
Po AlmaLinuxu byl v nové stabilní verzi 10.1 vydán také Rocky Linux. Přehled novinek v poznámkách k vydání.
Open source reimplementace počítačových her Tomb Raider I a Tomb Raider II spolu s dalšími vylepšeními a opravami chyb TRX byla vydána ve verzi 1.0. Jedná se o sloučení projektů / enginů TR1X a TR2X do jednoho TRX. Videoukázka na YouTube.
Společnost Seznam.cz spouští konverzační nástroj založený na umělé inteligenci Seznam Asistent. Asistent využívá vlastní jazykový model SeLLMa a dočasně i komerční modely od OpenAI provozované v evropských datacentrech prostřednictvím Microsoft Azure. Dlouhodobým cílem Seznamu je provozovat Asistenta výhradně na interních jazykových modelech a ve vlastních datových centrech.
M41dostat jako vystup :
M<41>. Potrebuju oddelit prvni pismeno a cisla za nim dat do sipek. Zkousel jsem :
slovo.split("") s tim ze bych si tam pak ty sipky concatoval, ale ten split() me to na pismena nerozdeli.
Pokud bych rozdelil slovo na pole charu, tak zas asi tezko concatuju ty sipky...
Mohl by nekdo poradit pls?
Řešení dotazu:
Pokud bych rozdelil slovo na pole charu, tak zas asi tezko concatuju ty sipky...Pak to pole projdeš v cyklu a pomocí StringBuilderu postupně sestavíš nový řetězec – na některá místa přidáš ty šipky. Měl bys ale upřesnit zadání. Proč chceš šipky přidat zrovna kolem 41? Možná by se ti hodily regulární výrazy – definuješ si vzor, ten může obsahovat skupiny (části textu) a ty si pak vytáhneš a třeba obalíš šipkami.
char[] charArray = word.toCharArray();
String temp = Character.toString(charArray[0]); //getting object letter
Pattern pattern = Pattern.compile("^"+temp+"(\\d+)$"); //setting a regex pattern
Matcher matcher = pattern.matcher(word);
if(!(matcher.matches())) {
throw new CatalogIOException("wrong ID format");
}
String ID = temp.concat("<").concat(matcher.group(1)).concat(">"); //matcher.gorup(1) returns a string with the object number
Místo vymýšlení nějakého pseudojazyka s čísly v závorkách z toho udělej instance nějaké tvé třídy, kde to číslo bude uložené jako int v privátní proměnné.
s/^([a-z])([0-9]+)/$1<$2>/i;
"M41".replaceAll("([0-9]+)", "<$1>")
(a při opakovaném použití je dobré si regulární výrazy předkompilovat)
public static String updateText(String str) {
StringBuffer updatedText = new StringBuffer();
Matcher matcher = Pattern.compile("\\d+").matcher(str);
while(matcher.find()) {
String group = matcher.group();
StringBuilder replacement = new StringBuilder();
replacement.append("<").append(group).append(">");
matcher.appendReplacement(updatedText, replacement.toString());
}
matcher.appendTail(updatedText);
return updatedText.toString();
}
no to potes, takova prasarna... proc navic komentujete 100 dni stary dotaz, kde navic padlo elegantni reseni?
import java.util.Date;
import java.util.regex.Matcher;
import java.util.regex.Pattern;
public class Test {
private static final String TEST_STRING = "M23";
public static void main(String[] args) {
Date d = new Date();
Pattern pattern = Pattern.compile("\\d+");
for(int i = 0; i < 10000000; i++) {
TEST_STRING.replaceAll("([0-9]+)", "<$1>");
}
System.out.println(new Date().getTime() - d.getTime());
d = new Date();
for(int i = 0; i < 10000000; i++) {
updateText(pattern, TEST_STRING);
}
System.out.println(new Date().getTime() - d.getTime());
}
public static String updateText(Pattern pattern, String str) {
StringBuffer updatedText = new StringBuffer();
Matcher matcher = pattern.matcher(str);
while(matcher.find()) {
String group = matcher.group();
StringBuilder replacement = new StringBuilder();
replacement.append("<").append(group).append(">");
matcher.appendReplacement(updatedText, replacement.toString());
}
matcher.appendTail(updatedText);
return updatedText.toString();
}
}
Tiskni
Sdílej: