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.
Byla vydána nová verze 10.1 sady aplikací pro SSH komunikaci OpenSSH. Uživatel je nově varován, když se nepoužívá postkvantovou výměnu klíčů.
Byly zpracovány a na YouTube zveřejněny videozáznamy z konference LinuxDays 2025.
Na konferenci LinuxDays 2025 byl oficiálně představen nový router Turris Omnia NG.
Přímý přenos (YouTube) z konference LinuxDays 2025, jež probíhá tento víkend v Praze v prostorách FIT ČVUT. Na programu je spousta zajímavých přednášek.
V únoru loňského roku Úřad pro ochranu osobních údajů pravomocně uložil společnosti Avast Software pokutu 351 mil. Kč za porušení GDPR. Městský soud v Praze tuto pokutu na úterním jednání zrušil. Potvrdil ale, že společnost Avast porušila zákon, když skrze svůj zdarma dostupný antivirový program sledovala, které weby jeho uživatelé navštěvují, a tyto informace předávala dceřiné společnosti Jumpshot. Úřad pro ochranu osobních údajů
… více »Google Chrome 141 byl prohlášen za stabilní. Nejnovější stabilní verze 141.0.7390.54 přináší řadu novinek z hlediska uživatelů i vývojářů. Podrobný přehled v poznámkách k vydání. Opraveno bylo 21 bezpečnostních chyb. Za nejvážnější z nich (Heap buffer overflow in WebGPU) bylo vyplaceno 25 000 dolarů. Vylepšeny byly také nástroje pro vývojáře.
eDoklady mají kvůli vysoké zátěži technické potíže. Ministerstvo vnitra doporučuje vzít si sebou klasický občanský průkaz nebo pas.
Tohle udelat nejde, proc si dynamicky nenaalokujes pole tech promenych?
Uvedeny program je nesmysl. Popis co potrebujes udelat a pak ti nekdo snad poradi.
Tohle je totalni prasecina. K cemu to je vubec dobre?
Btw, pred pouzitim musi byt promenna nejprve deklarovana cimz se urcuje jaky je jeji typ (coz potrebuje znat prekladac). Definice urcuje hodnotu deklarovane promenne. Takze jiz z principu to nemuze jit.
Pod pojmem definice se míní příkaz, který přidělí proměnné určitého typu jméno a paměť. Naopak deklarace je příkaz, který pouze udává typ proměnné a její jméno. Deklarace nepřiděluje žádnou paměť!Pavel Herout, Učebnice jazyka C, odstavec 3.1.1, 3. upravené vydání
malloc()
a smerníkovú aritmetiku?
Nesmim u toho pouzit pole, coz se v tomto pripade i me jevi jako nejjednodussi reseni.Patrne nemôžeš použiť staticky alokované pole a puntičkári by mohli dokonca tvrdiť, že to ani nejde, nakoľko používateľ môže vždy požadovať o jeden parameter viac ako Ty naalokuješ staticky. Čo ale IMHO máš použiť je dynamicky alokované pole správnej veľkosti. Takže navrhujem nasledujúci postup: 1) Prečítať prvý parameter udávajúci počet premenných. 2) Dynamicky alokovať pole pre daný počet hodnôt očakávaného typu. 3) Postupne čítať jednotlivé hodnoty a ukladať ich do poľa. 4) Opätovne preiterovať pole a hodnoty vypísať. Vypísanie mena premennej v tvare x#, kde # je jej poradové číslo je iba cvičenie na použitie
printf()
.
To by me vazne zajimalo, jake je presne zneni zadani.
C je staticky typovany jazyk, tzn. ze nemuzete za behu programu vytvaret "normalni" promenne a davat jim za behu generovana jmena.
Myslim, ze by melo stacit, ...Keď myslíš, pokojne to tak urob. Rovnako pokojne ignoruj to, čo sa Ti tu od začiatku snažíme vysvetliť: že to nejde.
Dejte sem presne zneni zadani.
Pocet dimenzi budete znat v dobe prekladu, parametr -DDIM=2
predany prekladaci na prikazove radce je ekvivalentem #define DIM 2
napsanym na zacatku zdrojaku. Take tam stoji, ze DIM
bude od 1 do 3, takze nemusite koumat nad zcela obecnym pripadem.
Pro reseni "bonusu" se naprosto idealne hodi pole, ta poznamka se podle me vztahuje k zakladnimu prikladu, ktery opravdu jde jednoduse napsat bez poli.
#define spoj(a,b) a##b
je makro pro preprocesor. Preprocesor je věc, která se proběhne po zdrojáku před "skutečným" překladačem a vyřádí se na zdrojovém textu - tato makra neoperují s proměnnými, ale s textem zdrojáku. Takže expanze tohoto makra ve Vašem případě dopadne takto:
int spoj(x,*i);
int x*i;
což následně při průchodu překladačem bude vyhodnoceno jako syntaktická chyba. V definici proměnné může být za jménem buď rovnou středník, nebo třeba rovnítko a inicializace na počáteční hodnotu, ale ne operátor násobení.
Jak už tu někdo řekl, je to o statickém typování. Preprocesorem si můžete rozplemenit proměnné ve fázi kompilace (resp. před vlastní kompilací). Za běhu už bude množina staticky deklarovaných proměnných pevně dána.
Nešlo by napsat Váš algoritmus tím způsobem, že si přes jedinou proměnnou postupně načte jednu až tři vstupní hodnoty a nějak je postupně "akumuluje" do výsledku? To by se obešlo i bez dynamických alokací a bez polí. Sice to trochu smrdí bílým trpaslíkem, ale co naplat, když rozmáchlejší styl zatím používat nesmíte (nemáte ho umět)
Pokud nesmíš použít pole, tak by to šlo ještě řešit rekurzí. Nebude to asi to, kam mířilo zadání :) A nic moc jiného než vytištění hodnot v opačném pařadí, než je uživatel zadal sice asi nespácháš, ale procvičíš se v rekurzi.
Tiskni
Sdílej: