Google postupně zpřístupňuje českým uživatelům Režim AI (AI Mode), tj. nový režim vyhledávání založený na umělé inteligenci. Režim AI nabízí pokročilé uvažování, multimodalitu a možnost prozkoumat jakékoliv téma do hloubky pomocí dodatečných dotazů a užitečných odkazů na weby.
Programovací jazyk Python byl vydán v nové major verzi 3.14.0. Podrobný přehled novinek v aktualizované dokumentaci.
Bylo oznámeno, že Qualcomm kupuje Arduino. Současně byla představena nová deska Arduino UNO Q se dvěma čipy: MPU Qualcomm Dragonwing QRB2210, na kterém může běžet Linux, a MCU STM32U585 a vývojové prostředí Arduino App Lab.
Multiplatformní open source voxelový herní engine Luanti byl vydán ve verzi 5.14.0. Podrobný přehled novinek v changelogu. Původně se jedná o Minecraftem inspirovaný Minetest v říjnu loňského roku přejmenovaný na Luanti.
Byla vydána nová stabilní verze 6.10 (YouTube) multiplatformního frameworku a GUI toolkitu Qt. Podrobný přehled novinek v poznámkách k vydání.
Netwide Assembler (NASM) byl vydán v nové major verzi 3.00. Přehled novinek v poznámkách k vydání v aktualizované dokumentaci.
Linuxová distribuce Frugalware (Wikipedie) ke konci roku 2025 oficiálně končí.
Byla vydána nová verze 3.0.6 svobodné aplikace pro úpravu a vytváření rastrové grafiky GIMP (GNU Image Manipulation Program). Přehled novinek v oznámení o vydání a v souboru NEWS na GitLabu. Nový GIMP bude brzy k dispozici také na Flathubu.
Americký výrobce čipů AMD uzavřel s americkou společností OpenAI smlouvu na několikaleté dodávky vyspělých mikročipů pro umělou inteligenci (AI). Součástí dohody je i předkupní právo OpenAI na přibližně desetiprocentní podíl v AMD.
class A { typedef std::vector< MujObjekt> VectorOfMujObject; typedef std::vector< VectorOfMujObjekt> VectorOfVectorOfMujObject; VectorOfVectorOfMujObject vovomo; public: A() : vovomo(100) // vlozi 100 prvku inicializovanych default constructorem, tedy prazdnych vektoru { vovomo[0].push_back(Z(1, 2, 3)); } };
#include < iostream > #include < string > #include < vector > typedef std::vector < std::string > SVect; typedef std::vector < SVect > VSVect; int main() { std::vector < std::string > v1; v1.push_back("A1"); v1.push_back("B1"); v1.push_back("C1"); std::vector < std::string > v2; v2.push_back("A2"); v2.push_back("B2"); VSVect sv; sv.push_back(v1); sv.push_back(v2); for (VSVect::const_iterator cit = sv.begin(); cit != sv.end(); cit++) { for (SVect::const_iterator icit = cit->begin(); icit != cit->end(); icit++) { std::cout << *icit << " "; } std::cout << std::endl; } return 0; }
vector<vector<C> > vector_of_vectors_of_c;Pokud ale hodlas menit pocet prvku v tom hlavnim vektoru a nepouzivas posledni normu jazyka C++, kde se pri realokaci muze udelat move, tak bych tam dal ukazatele na vektory:
vector<vector<C> *> vector_of_vectors_of_c;A jestli ta trida ma velkou velikost, nebo slozity kopirovani tak bych dal ukazatel i tam
vector<vector<C *> *> vector_of_vectors_of_c;
Protoze napr implementace stl u gcc, alokuje pri realokaci vzdy dvojnasobek pameti a nikdy nezmensuje.Tohle je zrovna vlastnost, která se mi moc nehodí. Potřebuji v každé úrovni vždy vygenerovat větší množství prvků a pak ty pro další fáze nepotřebné promazat. Možná by byla lepší jiná struktura než vektor, jestli třeba
list
nemá paměťově efektivnější implementaci.
Tiskni
Sdílej: