Byla vydána nová stabilní verze 7.9 webového prohlížeče Vivaldi (Wikipedie). Postavena je na Chromiu 146. Přehled novinek i s náhledy v příspěvku na blogu.
Dle plánu byla vydána Opera GX pro Linux. Ke stažení je .deb i .rpm. V plánu je flatpak. Opera GX je webový prohlížeč zaměřený na hráče počítačových her.
GNUnet (Wikipedie) byl vydán v nové major verzi 0.27.0. Jedná se o framework pro decentralizované peer-to-peer síťování, na kterém je postavena řada aplikací.
Byly publikovány informace (technické detaily) o bezpečnostním problému Snapu. Jedná se o CVE-2026-3888. Neprivilegovaný lokální uživatel může s využitím snap-confine a systemd-tmpfiles získat práva roota.
Nightingale je open-source karaoke aplikace, která z jakékoliv písničky lokálního alba (včetně videí) dokáže oddělit vokály, získat text a vše přehrát se synchronizací na úrovni jednotlivých slov a hodnocením intonace. Pro separaci vokálů využívá UVR Karaoke model s Demucs od Mety, texty písní stahuje z lrclib.net (LRCLIB), případně extrahuje pomocí whisperX, který rovněž využívá k načasování slov. V případě audiosouborů aplikace na
… více »Po půl roce vývoje od vydání verze 49 bylo vydáno GNOME 50 s kódovým názvem Tokyo (Mastodon). Podrobný přehled novinek i s náhledy v poznámkách k vydání a v novinkách pro vývojáře.
Článek na stránkách Fedora Magazinu informuje o vydání Fedora Asahi Remixu 43, tj. linuxové distribuce pro Apple Silicon vycházející z Fedora Linuxu 43.
Byl zveřejněn program konference Installfest 2026. Konference proběhne o víkendu 28. a 29. března v Praze na Karlově náměstí 13. Vstup zdarma.
Byla vydána Java 26 / JDK 26. Nových vlastností (JEP - JDK Enhancement Proposal) je 10. Odstraněno bylo Applet API.
Byla vydána nová verze 260 správce systému a služeb systemd (Wikipedie, GitHub). Odstraněna byla podpora skriptů System V. Aktualizovány byly závislosti. Minimální verze Linuxu z 5.4 na 5.10, OpenSSL z 1.1.0 na 3.0.0, Pythonu z 3.7.0 na 3.9.0…
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: