Tento týden byla vydána nová verze 1.52 webového prohlížeče Brave (Wikipedie, GitHub). Postavena je na Chromiu 114. Z novinek lze vypíchnout možnost povolit vertikální karty (vertical tabs). Také bylo představeno Brave Search API k vyhledávači Brave Search.
Matthias Clasen z Red Hatu oznámil v diskusním listu vývojářů Fedora Linuxu, že tým Red Hat Display Systems se zaměří na Wayland a podporu HDR na Linuxu a přestane spravovat RPM balíčky pro LibreOffice. V další major verzi RHELu už LibreOffice nebude. Pokud se nenajde správce balíčků pro Fedora Linux, zůstane pouze LibreOffice ve Flatpaku.
Na Steamu lze získat zdarma počítačovou hru Tell Me Why (ProtonDB). Na Epic Games Storu počítačovou hru Midnight Ghost Hunt (ProtonDB).
Společnost Meta představila (YouTube) brýle pro virtuální realitu Meta Quest 3. V prodeji budou na podzim a stát budou od 499,99 dolarů.
Byla vydána nová verze 2.41.0 distribuovaného systému správy verzí Git. Přispělo 95 vývojářů, z toho 29 nových. Přehled novinek v příspěvku na blogu GitHubu a v poznámkách k vydání.
Organizace Apache Software Foundation (ASF) vydala verzi 18 integrovaného vývojového prostředí a vývojové platformy napsané v Javě NetBeans (Wikipedie). Přehled novinek na GitHubu. Instalovat lze také ze Snapcraftu a Flathubu.
Byla vydána verze 1.70.0 programovacího jazyka Rust (Wikipedie). Podrobnosti v poznámkách k vydání. Vyzkoušet Rust lze například na stránce Rust by Example. Jako reakce na rostoucí obavy z vlivu korporací na vývoj Rustu a předložený návrh restriktivních zásad používání ochranných známek Rustu, byl nedávno představen komunitní fork Rustu se 100 % méně byrokracie: Crab (CrabLang).
Oliver Smith z Canonicalu shrnuje základní vlastnosti „neměnné“ distribuce Ubuntu Core také ve srovnání s protějšky Chrome OS, Fedora Silverblue a MicroOS. Canonical připravuje desktopovou variantu Ubuntu Core vedle dosavadní serverové/embedded.
Z aktualizovaného seznamu chyb (pdf) procesoru AMD EPYC 7002: #1474 - procesor se po 1044 dnech od posledního resetu zasekne [reddit].
Fossil (Wikipedie) byl vydán ve verzi 2.22. Jedná se o distribuovaný systém správy verzí propojený se správou chyb, wiki stránek a blogů s integrovaným webovým rozhraním. Vše běží z jednoho jediného spustitelného souboru a uloženo je v SQLite databázi.
Řešení dotazu:
IF „hlad“ GOTO „lednice“
if
není funkce. A když už bys to rád dělal nějak divně složitě, proč to neuděláš pomocí operátorů & | ^
?
if
? Chceš efektivní algoritmus pro celočíselné mocniny? Všechno lze zařídit!
double mocnina(double x, int i) { double r = 1.0; if (!i) return 1.0; bool negative = false; if (i < 0) { negative = true; i = -i; } for ( ; ; ) { if (i & 1) r *= x; if (!(i >>= 1)) break; x *= x; } return negative ? 1.0/r : r; }Jen nevím, jak budeš vysvětlovat, jak to funguje...
double mocnina(double x,int y) { return x*(y>1?mocnina(x,--y):1); }
if
. Cílem bylo mít tam nějaké if
y ;)
double mocnina(double x,int y) { if (y>1) return x*mocnina(x,--y); else return 1; }Ale jinak je to blbost dobrá akorát na hraní.
Je tam chyba.
Má tam byť:
else
return x;
if (y>0)
Jirka
if
y ;)
template <int base, int pow> struct mocnina { enum { value = base * mocnina<base, pow - 1>::value }; }; template <int base> struct mocnina<base, 0> { enum { value = 1 }; };
error: template instantiation depth exceeds maximum of 900
jsem zkoušel vytvořitAno? A ako ďaleko si sa dostal?
int mocnina(int x,y) { if (y == 2) return x*x; if (y == 3) return x*x*x; if (y == 4) return x*x*x*x; if (y == 5) return x*x*x*x*x; if (y == 6) return x*x*x*x*x*x; if (y == 7) return x*x*x*x*x*x*x; if (y == 8) return x*x*x*x*x*x*x*x; if (y == 9) return x*x*x*x*x*x*x*x*x; if (y == 10) return x*x*x*x*x*x*x*x*x*x; if (y == 11) return x*x*x*x*x*x*x*x*x*x*x; if (y == 12) return x*x*x*x*x*x*x*x*x*x*x*x; if (y == 13) return x*x*x*x*x*x*x*x*x*x*x*x*x; if (y == 14) return x*x*x*x*x*x*x*x*x*x*x*x*x*x; if (y == 15) return x*x*x*x*x*x*x*x*x*x*x*x*x*x*x; if (y == 16) return x*x*x*x*x*x*x*x*x*x*x*x*x*x*x*x; if (y == 17) return x*x*x*x*x*x*x*x*x*x*x*x*x*x*x*x*x; if (y == 18) return x*x*x*x*x*x*x*x*x*x*x*x*x*x*x*x*x*x; if (y == 19) return x*x*x*x*x*x*x*x*x*x*x*x*x*x*x*x*x*x*x; return x; }Je to najlepsia verzia lebo obsahuje najviac ifov. Pre profesionalnu verziu si na zaciatok mozes doplnit assert(y<20);
void setup() { int x=10; int y=10; int q=mocnina(x,y); Serial.println(q); } int mocnina(int x,int y) { if (y == 2) return x*x; if (y == 3) return x*x*x; if (y == 4) return x*x*x*x; if (y == 5) return x*x*x*x*x; if (y == 6) return x*x*x*x*x*x; if (y == 7) return x*x*x*x*x*x*x; if (y == 8) return x*x*x*x*x*x*x*x; if (y == 9) return x*x*x*x*x*x*x*x*x; if (y == 10) return x*x*x*x*x*x*x*x*x*x; if (y == 11) return x*x*x*x*x*x*x*x*x*x*x; if (y == 12) return x*x*x*x*x*x*x*x*x*x*x*x; if (y == 13) return x*x*x*x*x*x*x*x*x*x*x*x*x; if (y == 14) return x*x*x*x*x*x*x*x*x*x*x*x*x*x; if (y == 15) return x*x*x*x*x*x*x*x*x*x*x*x*x*x*x; if (y == 16) return x*x*x*x*x*x*x*x*x*x*x*x*x*x*x*x; if (y == 17) return x*x*x*x*x*x*x*x*x*x*x*x*x*x*x*x*x; if (y == 18) return x*x*x*x*x*x*x*x*x*x*x*x*x*x*x*x*x*x; if (y == 19) return x*x*x*x*x*x*x*x*x*x*x*x*x*x*x*x*x*x*x; return x; } void loop() { }Binary sketch size: 4,084 bytes
void setup() { int x=10; int y=10; int q=mocnina(x,y); Serial.println(q); } int mocnina(int c,int y) { int x=c; if (y >= 2) x*=c; if (y >= 3) x*=c; if (y >= 4) x*=c; if (y >= 5) x*=c; if (y >= 6) x*=c; if (y >= 7) x*=c; if (y >= 8) x*=c; if (y >= 9) x*=c; if (y >= 10) x*=c; if (y >= 11) x*=c; if (y >= 12) x*=c; if (y >= 13) x*=c; if (y >= 14) x*=c; if (y >= 15) x*=c; if (y >= 16) x*=c; if (y >= 17) x*=c; if (y >= 18) x*=c; if (y >= 19) x*=c; return x; } void loop() { }Binary sketch size: 3,856 bytes
void setup() { int x=10; int y=10; int q=mocnina(x,y); Serial.println(q); } double mocnina(double cislo, int umocni_na) { int i, vysledok = 1; for (i = 1; i <= umocni_na; i++) vysledok *= cislo; return vysledok; } void loop() { }Binary sketch size: 4,068 bytes
void setup() { int x=10; int y=10; int q=mocnina(x,y); Serial.println(q); } int mocnina(int cislo, int umocni_na) { int i, vysledok = 1; for (i = 1; i <= umocni_na; i++) vysledok *= cislo; return vysledok; } void loop() { }Binary sketch size: 3,454 bytes
void setup() { int x=10; int y=10; int q=mocnina(x,y); Serial.println(q); } double mocnina(double x,int y) { return x*(y>1?mocnina(x,--y):1); } void loop() { }Binary sketch size: 3,950 bytes
void setup() { int x=10; int y=10; int q=mocnina(x,y); Serial.println(q); } int mocnina(int x,int y) { return x*(y>1?mocnina(x,--y):1); } void loop() { }Binary sketch size: 3,474 bytes
0000000000400578 <main>: 400578: 48 83 ec 08 sub $0x8,%rsp 40057c: 48 be 00 e4 0b 54 02 mov $0x2540be400,%rsi 400583: 00 00 00 400586: bf 98 06 40 00 mov $0x400698,%edi 40058b: 31 c0 xor %eax,%eax 40058d: e8 d6 fe ff ff callq 400468 <printf@plt> 400592: 5a pop %rdx 400593: 31 c0 xor %eax,%eax 400595: c3 retq0x2540be400 = 10^10
Tiskni
Sdílej: