V přihlašovací obrazovce LightDM KDE (lightdm-kde-greeter) byla nalezena a již opravena eskalace práv (CVE-2025-62876). Detaily v příspěvku na blogu SUSE Security.
Byla vydána nová verze 7.2 živé linuxové distribuce Tails (The Amnesic Incognito Live System), jež klade důraz na ochranu soukromí uživatelů a anonymitu. Tor Browser byl povýšen na verzi 15.0.1. Další novinky v příslušném seznamu.
Česká národní banka (ČNB) nakoupila digitální aktiva založená na blockchainu za milion dolarů (20,9 milionu korun). Na vytvořeném testovacím portfoliu, jehož součástí jsou bitcoin, stablecoiny navázané na dolar a tokenizované depozitum, chce získat praktickou zkušenost s držením digitálních aktiv. Portfolio nebude součástí devizových rezerv, uvedla dnes ČNB v tiskové zprávě.
Apple představil iPhone Pocket pro stylové přenášení iPhonu. iPhone Pocket vzešel ze spolupráce značky ISSEY MIYAKE a Applu a jeho tělo tvoří jednolitý 3D úplet, který uschová všechny modely iPhonu. iPhone Pocket s krátkým popruhem se prodává za 149,95 dolarů (USA) a s dlouhým popruhem za 229,95 dolarů (USA).
Byla vydána nová stabilní verze 7.7 webového prohlížeče Vivaldi (Wikipedie). Postavena je na Chromiu 142. Přehled novinek i s náhledy v příspěvku na blogu.
Společnost Epic Games vydala verzi 5.7 svého proprietárního multiplatformního herního enginu Unreal Engine (Wikipedie). Podrobný přehled novinek v poznámkách k vydání.
Intel vydal 30 upozornění na bezpečnostní chyby ve svých produktech. Současně vydal verzi 20251111 mikrokódů pro své procesory.
Byla vydána říjnová aktualizace aneb nová verze 1.106 editoru zdrojových kódů Visual Studio Code (Wikipedie). Přehled novinek i s náhledy a videi v poznámkách k vydání. Ve verzi 1.106 vyjde také VSCodium, tj. komunitní sestavení Visual Studia Code bez telemetrie a licenčních podmínek Microsoftu.
Canonical pro své zákazníky, předplatitele Ubuntu Pro, prodloužil podporu Ubuntu LTS z 12 let na 15 let (Legacy add-on). Týká se verzí od 14.04 (Trusty Tahr).
Homebrew (Wikipedie), správce balíčků pro macOS a od verze 2.0.0 také pro Linux, byl vydán ve verzi 5.0.0. Nově je oficiálně podporován Linux ARM64/AArch64. Na stránce Homebrew Formulae lze procházet seznamem balíčků. K dispozici jsou také různé statistiky.
Dobrý den poradil by někdo s následujícím úkolem? (programovani v C)
mam zadané:
int cislo1[10] int cislo1[10] int soucin[10] int soucet[10] int rozdil[10] int podil[10]
bude se to počítat přes ukazatele, udelat uvedéné aritmeticke operace s dvěma čísly (cislo1,cislo2) a nevím jak na to, nějaké rady?
Řešení dotazu:
Jak vypadá kompletní zadání? Takhle se dá jen hádat.
Asi iterovat v cyklu for (int i = 0; i < 10; i++) a dělat výpočty s cislo1[i] … a ukládat do soucin[i] …
Před tím potřebuješ zkontrolovat, že jsou všechna pole správně dlouhá…
Domnievam sa, že ide o použitie pointrovej matematiky k prístupu k prvokom poľa. V tom prípade:
1. Ak a je pole a i je index prvku v tom poli, tak platí, že prvok poľa a[i] je na adrese a+i.
2. Keď máš adresu p, tak to, čo je na tej adrese získaš cez *p.
Z toho vyplýva, že a[i] je to isté ako *(a+i). Analogicky a[3] je to isté ako *(a+3). A teda napr. a[5]+a[6] je to isté ako (*(a+5)+*(a+6)).
Uvedené informácie by mali stačiť na to, aby si úlohu vyriešil.
jako já za tebe ten domácák udělám ale ty zase musíš udělat muj domácák na pondělí na čédinu ;D
tady je muj domácák
Proveďte grafický rozbor zadaných vět (větného pavouka) 1. Vím, že vás zajímá cizí literatura a že se s ní snažíte seznámit české čtenáře, a proto vám doporučuji tuto zajímavou práci, která obsahuje příspěvky k otázkám překládání. 2. Časem se naučil pracovat tak úsporně, že si všechno dobře rozvrhl, a proto mu ještě zbyl čas k tomu, aby se podíval na představení, které v divadle právě hráli. 3. Protože němečtí vojáci přiváděli stále posily, postavili proti nim Pražané barikády a statečně se bránili, ač měli prázdné ruce.
tady je tvuj domácák
#include <stdio.h>
#include <stdlib.h>
#define DELKA_POLE 10
int main()
{
//hádám že je máš zadaný předem jako
int cislaA[DELKA_POLE]={-4,-3,-2,-1,0,1,2,3,4,5};
int cislaB[DELKA_POLE]={-4,-3,-2,-1,0,1,2,3,4,5};
int soucet[DELKA_POLE];
int soucin[DELKA_POLE];
int rozdil[DELKA_POLE];
int podil[DELKA_POLE];
unsigned int iterace;
//předpokládám že s čísílkama pracuješ v párech
//jinak bys tam jako musel vnořit ještě jeden cyklík aby to bylo každej s každým
for(iterace=0;iterace<DELKA_POLE;iterace++)
{
//tohlencto je to skoro to samý jako int A=cislaA[iterace]
int A=*(cislaA+iterace);
int B=*(cislaB+iterace);
//takhle zase schováme čísílko do ukazatele
//je to jakože to samý co soucet[iterace]=A+B
*(soucet+iterace)=A+B;
*(soucin+iterace)=A*B;
*(rozdil+iterace)=A-B;
//se tě určitě šišlavej jouda na výpočetku pokusí napálit dělením nuličkou a nuličkou dělit normálně nejde :'(
if(B!=0)
*(podil+iterace)=A/B;
else
{
printf("nulickou nejde delit ty kantore jeden hloupej pitomej!!!\n");
exit(EXIT_FAILURE);
}
//ještě to v tý samým cyklu mužeme vypisovat a koukat na to
printf("A = %d B = %d\n",A,B);
printf("soucet[%d] = %d\n",iterace,*(soucet+iterace));
printf("soucin[%d] = %d\n",iterace,*(soucin+iterace));
printf("rozdil[%d] = %d\n",iterace,*(rozdil+iterace));
printf("podil[%d] = %d\n\n",iterace,*(podil+iterace));
}
exit(EXIT_SUCCESS);
}
int cislo1[10] = { 1, 4, 2, 8, 5, 6, 6, 8, 9, 9 };
int cislo2[10] = { 1, 2, 2, 4, 5, 6, 3, 8, 9, 3 };
int soucin[10];
int soucet[10];
int rozdil[10];
int podil[10];
#include <stddef.h>
#include <stdio.h>
int main()
{
size_t i;
for (i = 0; i < sizeof cislo1 / sizeof *cislo1; ++i) {
i[soucet] = i[cislo1] + i[cislo2];
i[rozdil] = i[cislo1] - i[cislo2];
i[soucin] = i[cislo1] * i[cislo2];
i[podil] = i[cislo1] / i[cislo2];
printf("cislo1=%i cislo2=%i soucet=%i rozdil=%i soucin=%i podil=%i\n", i[cislo1], i[cislo2], i[soucet], i[rozdil], i[soucin], i[podil]);
}
return 0;
}
bude se to počítat přes ukazatele
bude se to počítat přes ukazatele
bude se to počítat přes ukazatele
bude se to počítat přes ukazatele
bude se to počítat přes ukazatele
The definition of the subscript operator [] is that E1[E2] is identical to (*(E1+(E2))) Because of the conversion rules that apply to the binary + operator. it E1 is an array object (equivalently. a pointer to the initial element of an array object) and E2 is an integer. E1[E2] designates the E2-th element of E1 (counting from zero).
si myslim že se po nás jako fakt chce pointrová aritmetička ;D
#include <stddef.h>
#include <stdio.h>
int cislo1[10] = { 1, 4, 2, 8, 5, 6, 6, 8, 9, 9 };
int cislo2[10] = { 1, 2, 2, 4, 5, 6, 3, 8, 9, 3 };
int soucin[10];
int soucet[10];
int rozdil[10];
int podil[10];
int main()
{
int *p_cislo1 = cislo1;
int *p_cislo2 = cislo2;
int *p_soucin = soucin;
int *p_soucet = soucet;
int *p_rozdil = rozdil;
int *p_podil = podil;
for (; p_cislo1 < cislo1 + 10; ++p_cislo1, ++p_cislo2, ++p_soucin, ++p_soucet, ++p_rozdil, ++p_podil) {
0[p_soucet] = 0[p_cislo1] + 0[p_cislo2];
0[p_rozdil] = 0[p_cislo1] - 0[p_cislo2];
0[p_soucin] = 0[p_cislo1] * 0[p_cislo2];
0[p_podil ] = 0[p_cislo1] / 0[p_cislo2];
printf("cislo1=%i cislo2=%i soucet=%i rozdil=%i soucin=%i podil=%i\n", 0[p_cislo1], 0[p_cislo2], 0[p_soucet], 0[p_rozdil], 0[p_soucin], 0[p_podil]);
}
return 0;
}
Ta věta končila otazníkem – těžko říct, jestli to byla jen tazatelova domněnka nebo zadání. Proto se tu lidi ptali na původní zadání úkolu.
si myslim že napsal misto teček čárky jak byl jako zamyšlenej. když si tam ty tečky přectavíš tak to bude jakože dávat smysl ;D
Ůůůfff. Podobně jako někteří předřečníci, i já cítím potřebu odcitovat ze zadání ještě jednou:
bude se to počítat přes ukazatele
Takže je mi fakt záhadou, proč se tu objevují "řešení", ve kterých se to hemží hranatými závorkami.
Pokud jde o úkol na pointerovou aritmetiku, je rozumné předpokládat, že se má použít přímo pointerová aritmetika, ne syntactic sugar s hranatými závorkami.
Tady je to bez hranatých závorek (s výjimkou deklarací, samozřejmě):
#include <stddef.h>
#include <stdio.h>
void vypiš_pole(const char *const název,
const int *const začátek, const size_t velikost) {
printf("%s: {", název);
const int *const konec = začátek + velikost;
const int *u = začátek;
if (u < konec) {
printf("%d", *u);
for (++u; u < konec; ++u) { printf(", %d", *u); }
}
puts("}");
}
int main() {
const int číslo1[10] = {1, 2, 3, 4, 5, 6, 7, 8, 9, 10};
const int číslo2[10] = {10, 9, 8, 7, 6, 5, 4, 3, 2, 1};
int součin[10];
int součet[10];
int rozdíl[10];
int podíl[10];
int *součin_ukazatel = součin;
int *součet_ukazatel = součet;
int *rozdíl_ukazatel = rozdíl;
int *podíl_ukazatel = podíl;
const int *const číslo1_konec = číslo1 + sizeof(číslo1) / sizeof(int);
for (const int *číslo1_ukazatel = číslo1, *číslo2_ukazatel = číslo2;
číslo1_ukazatel < číslo1_konec;
++číslo1_ukazatel, ++číslo2_ukazatel) {
*součin_ukazatel++ = *číslo1_ukazatel * *číslo2_ukazatel;
*součet_ukazatel++ = *číslo1_ukazatel + *číslo2_ukazatel;
*rozdíl_ukazatel++ = *číslo1_ukazatel - *číslo2_ukazatel;
*podíl_ukazatel++ = *číslo1_ukazatel / *číslo2_ukazatel;
}
vypiš_pole("číslo1", číslo1, sizeof(číslo1) / sizeof(int));
vypiš_pole("číslo2", číslo2, sizeof(číslo2) / sizeof(int));
vypiš_pole("součin", součin, sizeof(součin) / sizeof(int));
vypiš_pole("součet", součet, sizeof(součet) / sizeof(int));
vypiš_pole("rozdíl", rozdíl, sizeof(rozdíl) / sizeof(int));
vypiš_pole("podíl", podíl, sizeof(podíl) / sizeof(int));
}
(Mimochodem, kdyby se to náhodou někomu (zase, tradičně, klasicky) nedařilo přeložit kvůli UCN, může si
(a) nainstalovat překladač hodný 21. století, který UCN zvládne (příklad: clang),
(b) přejmenovat identifikátory do angličtiny, která nevyžaduje diakritiku, nebo
(c) políbit prdel.)
součin_ukazatel.
Jestli ho dereferencujete pomocí operátoru * nebo pomocí pomocí syntactic sugar s hranatými závorkami je úplně jedno.
uplně blbě jako!!!!!!! >:C >:C >:C
odkud se ty čísla maj jako načítat?? mají se nějak zadat jako argument toho programu při spuštění nebo ze standatrního vstupu?? to dělení je celošíselný nebo z tou jakože plovoucí čárkou?? je fakt těch čícel co se má zadat deset?? musíš nám o tom zadání říct jako víc tohleto je fakt jako vaření z vody :'(
upravila jsem svuj předchozí zdrojáček
#include <stdio.h>
#include <stdlib.h>
//TODO:fakt jich má bejt deset?? nemá se nás to nejdřiv zeptat kolik jich tam chceme strčit??
#define DELKA_POLE 10
int main()
{
int cislaA[DELKA_POLE];
int cislaB[DELKA_POLE];
int soucet[DELKA_POLE];
int soucin[DELKA_POLE];
int rozdil[DELKA_POLE];
int podil[DELKA_POLE];//TODO:má to bejt celočíselný dělení nebo ne?? vtom tvým výsřižku je double
unsigned int iterace;
//nejdřiv si naplníme ty políčka čísílkama ze standartního vstupu
//to jako znamená že si to pustíš v terminálku a bude to po tobě chtít
//ty čísílka zadávat
for(iterace=0;iterace<DELKA_POLE;iterace++)
{
printf("zadej %d. cislo A: ",iterace+1);
scanf("%d",(cislaA+iterace));
printf("zadej %d. cislo B: ",iterace+1);
scanf("%d",(cislaB+iterace));
}
//předpokládám že s čísílkama pracuješ v párech
//jinak bys tam jako musel vnořit ještě jeden cyklík aby to bylo každej s každým
for(iterace=0;iterace<DELKA_POLE;iterace++)
{
//tohlencto je to skoro to samý jako int A=cislaA[iterace]
int A=*(cislaA+iterace);
int B=*(cislaB+iterace);
//takhle zase schováme čísílko do ukazatele
//je to jakože to samý co soucet[iterace]=A+B
*(soucet+iterace)=A+B;
*(soucin+iterace)=A*B;
*(rozdil+iterace)=A-B;
//se tě určitě šišlavej jouda na výpočetku pokusí napálit dělením nuličkou a nuličkou dělit normálně nejde :'(
if(B!=0)
*(podil+iterace)=A/B;
else
{
printf("nulickou nejde delit ty kantore jeden hloupej pitomej!!!\n");
exit(EXIT_FAILURE);
}
//ještě to v tý samým cyklu mužeme vypisovat a koukat na to
printf("A = %d B = %d\n",A,B);
printf("soucet[%d] = %d\n",iterace,*(soucet+iterace));
printf("soucin[%d] = %d\n",iterace,*(soucin+iterace));
printf("rozdil[%d] = %d\n",iterace,*(rozdil+iterace));
printf("podil[%d] = %d\n\n",iterace,*(podil+iterace));
}
exit(EXIT_SUCCESS);
}
int i; int pole[10]; long int sum; int *p; sum=0; p=pole; for(i=0; i<10; i++, p++) sum+=*p;
nevim je to tak 50:50 si myslim ;D
neregistrovanej dooyer je určo trol ale nemusí to jako bejt původní tazatel ;D
jako že to tady je zatrolený by věděl jenom pravidelnej náštěvník abclinuxu a žádnej pravidelnej náštěvník abclinuxu by neměl s domácákem z cčka problém. si teda jako aspoň myslim že to tak je ;D
jóóóóóóóóóóó domácák z čédiny to je uplně něco jinýho. už ho máš udělanej?? sem si ho teda už dávno včera obšlehla o přestávce před čédinou ale stejně ho chci ještě jednou udělat vod tebe. kšeft je kšeft ;D
a žádnej pravidelnej náštěvník abclinuxu by neměl s domácákem z cčka problém. si teda jako aspoň myslim že to tak jeNení, prudím tady od 2007, a uvedený úkol bych zvládl až někdy od 2014.
ti ale cčkovej domácák nikdo taky nezadal ne?? si ale myslim že kdybys to tenkrát jako musel udělat tak bys to prostě udělal ;D
já tomu tvýmu taky nerozuměla a pokusila sem se jako :D :D
V ob_lném pol_ u b_lé v_l_ v_lné v_l_ chv_l_ b_l_ z ob_l_ v_nk_ v_l_ a churav_ ps_ na ně z v_l_ kv_l_vě v_l_, jako b_ je v_l_ v té chv_l_ b_val_ b_l_ b_l_.A konečně jsem měl čas trochu si pohrát a ke zde uvedeným špatným řešením přidat svoje, také špatné
#include <stdio.h>
#include <limits.h>
#define N (10)
int i, cislo1[N]={0}, cislo2[N]={0}, soucet[N], rozdil[N], soucin[N], podil[N];
int main(void)
{
printf("Zadej první sadu: ");
for (i=0; i<N; ++i) scanf("%d", cislo1+i);
printf("Zadej druhou sadu: ");
for (i=0; i<N; ++i) scanf("%d", cislo2+i);
for (i=0;i<N;++i)
*(soucet+i) = *(cislo1+i) + *(cislo2+i),
*(rozdil+i) = *(cislo1+i) - *(cislo2+i),
*(soucin+i) = *(cislo1+i) * *(cislo2+i),
*(podil+i) = *(cislo2+i)? *(cislo1+i) / *(cislo2+i): INT_MAX;
printf("\nsoucet\trozdil\tsoucin\tpodil\n");
for (i=0; i<N; ++i) printf("%d\t%d\t%d\t%d\n", soucet[i], rozdil[i], soucin[i], podil[i]);
return 0;
}
brnkačka jako :D :D
V obilném poli u bělé volá volné vole chvělo bylo z obělu venku válí a churavě psa na ně z vole kválově válo, jako by je vole v té chvále bývalo bylo bilo.
#include <stdio.h>
enum {N = 10};
void input(int n, int *n1, int *n2)
{
while (n-- > 0)
scanf("%d%d", n1++, n2++);
}
void calc(int n, int *n1, int *n2,
int *a, int *s, int *m, int *d) {
while (n-- > 0) {
*a++ = *n1 + *n2;
*s++ = *n1 - *n2;
*m++ = *n1 * *n2;
*d++ = *n1++ / *n2++;
}
}
void print(int n, int *n1, int *n2,
int *a, int *s, int *m, int *d) {
while (n-- > 0) {
printf("%d + %d = %d\n", *n1, *n2, *a++);
printf("%d - %d = %d\n", *n1, *n2, *s++);
printf("%d * %d = %d\n", *n1, *n2, *m++);
printf("%d / %d = %d\n\n", *n1++, *n2++, *d++);
}
}
int main()
{
int cislo1[N];
int cislo2[N];
int soucet[N];
int rozdil[N];
int soucin[N];
int podil[N];
input(N, cislo1, cislo2);
calc(N, cislo1, cislo2, soucet,
rozdil, soucin, podil);
print(N, cislo1, cislo2, soucet,
rozdil, soucin, podil);
return 0;
}
Tiskni
Sdílej: