Vývojáři mobilní Datovky prosí o pomoc s testováním beta verze mobilní Datovky s novým grafickým rozhraním, podporou pro tmavý režim a podporou pro VoDZ. Aplikace je zatím dostupná pouze pro zařízení Android a je umístěna v samostatném instalačním kanále Datovka Beta. Tento kanál slouží pro testovaní nové funkcionality a grafického uživatelského rozhraní. Datovka Beta se instaluje jako samostatná aplikace s vlastními daty, která
… více »Harlequin byl vydán ve verzi 1.0.0. Jedná se o TUI (Text User Interface) IDE (Integrated Development Environment) k systému pro správu SQL OLAP databází DuckDB.
Po roce a půl od představení DALL·E 2 představila společnost OpenAI novou verzi DALL·E 3 svého AI systému pro generování "realisticky vypadajících obrázků nebo uměleckých děl" na základě popisu v přirozeném jazyce, viz příklad "kosmonaut na koni fotorealisticky". Jednou z novinek je integrace s ChatGPT.
Nová čísla časopisů od nakladatelství Raspberry Pi: MagPi 133 (pdf) a HackSpace 70 (pdf).
Po půl roce vývoje od vydání verze 44 bylo vydáno GNOME 45 s kódovým názvem Rīga. Přehled novinek i s náhledy v poznámkách k vydání a v novinkách pro vývojáře. Krátké představení na YouTube. Jednou z nejviditelnějších změn je odstranění tlačítka Činnosti (Activities) v levém horním rohu. Nově je tam indikátor ploch. Výchozím prohlížečem obrázků je nově Loupe, nahradil Eye of GNOME (eog). Novou aplikací pro práci s webovou kamerou je Snapshot, nahradil Cheese. Rozšíření GNOME Shellu fungující v předchozích verzích nejsou s verzí 45 kompatibilní.
Linux Foundation představila a zaštítila svobodný a otevřený fork Terraformu s názvem OpenTofu. Ten vznikl pod původním názvem OpenTF jako reakce na přelicencování Terraformu na BSL (Business Source License) společností HashiCorp.
Google oznámil (en), že konverzační AI Bard (Wikipedie) může nyní komunikovat s aplikacemi a službami Google: "Díky nejnovějšímu rozšíření služby může Bard najít a zobrazit relevantní informace z nástrojů společnosti Google, které používáte každý den, jako je například Gmail, Dokumenty, Disk, Mapy, YouTube a Letenky Google, a to i když jsou potřebné informace v různých aplikacích a službách."
Apache Pinot (GitHub, Wikipedie) dospěl do verze 1.0. Jedná se o realtimeový distribuovaný OLAP datastore navržený tak, aby na OLAP dotazy odpovídal s nízkou latencí.
Byla vydána Java 21 / JDK 21. Nových vlastností (JEP - JDK Enhancement Proposal) je 15. Jedná se o LTS verzi. Nová Java / JDK vychází každých 6 měsíců.
Byla vydána betaverze Fedora Linuxu 39, tj. poslední zastávka před vydáním finální verze, která je naplánována na úterý 17. října. Nový Fedora Linux přinese GNOME 45, LibreOffice 7.6, GCC 13.2, …
Dobry vecer,
Mam napriklad funkciu:
int sucetPrvkovPola(int *x,int k)
{
int i,s=0;
for(i=0; i<k; i++)
{
s=s+x[i];
}
return s;
}
Napriklad ked sa program pokusi scitat dva prvky s hodnotami 2 000 000 000 a napriklad 2 000 500 000 co dava spolu vacsiu hodnotu ako je rozsah integeru. Vtedy by mala funkcia skoncit s chybovym hlasenim. Neviem si s tym poradit.
Dik
Řešení dotazu:
s
ako long a tú testovať na INT_MAX a INT_MIN.
long long int
a kompilovať to s voľbou -std=c99
.
int a,b ... if ((a > 0) && (b > 0) && (INT_MAX - a > b)) printf("a+b pretece"); if ((a < 0) && (b < 0) && (a < INT_MIN - b)) printf("a+b podtece");Varianta 2:
int a,b ... int c = a+b; if ((a > 0) && (c < b)) printf("a+b preteklo"); if ((a < 0) && (c > b)) printf("a+b podteklo");
A jak byste pánové chtěli detekovat přetečení long longu? "To nejde"?No predsa long long longom... :P
Catching Integer Overflows in C
Here is a complete set of three functions for ``careful'' addition, subtraction, and multiplication.:
#include <stdio.h> #include <limits.h> int chkadd(int a, int b) { if(b < 0) return chksub(a, -b); if(INT_MAX - b < a) { fputs("int overflow\n", stderr); return INT_MAX; } return a + b; } int chksub(int a, int b) { if(b < 0) return chkadd(a, -b); if(INT_MIN + b > a) { fputs("int underflow\n", stderr); return INT_MIN; } return a - b; } int chkmul(int a, int b) { int sign = 1; if(a == 0 || b == 0) return 0; if(a < 0) { a = -a; sign = -sign; } if(b < 0) { b = -b; sign = -sign; } if(INT_MAX / b < a) { fputs("int overflow\n", stderr); return (sign > 0) ? INT_MAX : INT_MIN; } return sign * a * b; }
epic fail!return chksub(a, -b);
chkadd()
se volá
chksub(a, -b)
pouze, když je
b
záporné číslo.
Tedy v
chksub()
se nemůže zavolat
chkadd(a, -b)
,
protože ze záporného
b
se udělalo kladné, tedy žádná nekonečná rekurze se nekoná.
Pokud si někdo myslí opak, uveďte konkrétní příklad, možná se na to jen nedívám z dostatečného odstupu a stále mi něco uniká. main() {int i = -2147483648; printf ("%x %x %s\n", i, (-i), (i == -i)?"pooh":""); }To je svinské číslo, které je záporné, i když se z něj veme absolutní hodnota :) Holt matematika a numerická matematika jsou dvě různé věci, s floating point čísly je to ještě horší.
Ach ta nepozornost, hlavně, že mají před začátkem kódu poznámku:
(Note: these functions all share one bug: they may fail if invoked on the largest negative integer, INT_MIN.)
Za druhé - "detekci přetečení uděláme tak, že použijeme číslo s větším rozsahem" - wtf? A jak byste pánové chtěli detekovat přetečení long longu? "To nejde"?V zadání se sčítaly tuším dva 32bit integery, mám takový dojem, že při sečtení se 64bit limit nikdy nepřekročí :-P.
Tiskni
Sdílej: