Diskuze: Proč je C krásně i děsivé zároveň?
V předchozím kvízu, Online test znalostí C++, jsme si ověřili nabyté zkušenosti z kurzu.
Tvůrce
Zobrazeno 12 zpráv z 12.
//= Settings::TRACKING_CODE_B ?> //= Settings::TRACKING_CODE ?>
V předchozím kvízu, Online test znalostí C++, jsme si ověřili nabyté zkušenosti z kurzu.
Pěkné. Musel jsem si to nejprve zkompilovat, abych zjistil, co to má dělat. Teprve po několika minutách jsem pochopil, proč to funguje.
Takto je to tiež zaujímavé.
#include <stdio.h>
int main(int argc, char *argv[])
{
int p[] = { 10, 20, 30, 0, 40, 50 }, *r = 0[&p], q = 0;
while (0[r])
q += 0[r++];
printf("%d\n", 0[&q]);
return 0;
}
V C nedělám, mohl by mi někdo říct, co to dělá?
int main(void)
{
int p[] = { 10, 20, 30, 40, 50, 0 }; // vytvorí pole int-ov
int *r = 0[&p]; / do pointeru *r vloží adresu prvého prvku pola p[]
int q = 0;
while (0[r]) { // cyklus beží kým v je na adrese prvok väčší ako nula
q += 0[r++]; // prechádza adresy poľa a spočítava ich
}
printf("%d\n", 0[&q]); // vypíše obsah adresy
return 0;
}
Dúfam, že som to správne popísal.
Pole a index jdou ve výrazu prohodit V tom je celý vtip.
Samozrejme, že sa to dá riešiť aj bez pointerov a potom sa do dá použiť aj v iných jazykoch.
int p[] = {10, 20, 30, 40, 50, 0}, r = 0, q = 0;
while (p[r])
q += p[r++];
printf("%d\n", q); // výstup si vie každý upraviť podľa jazyka
Řešení od C# juniora:
int[] p = new int[] { 10, 20, 30, 40, 50, 0 };
int q = p.Sum();
Řešení od C# seniora:
List<int> p = new List<int>(new int[] { 10, 20, 30, 40, 50, 0 });
int q = p.Sum();
Řešení, když nebereš dostatek vitaminu:
Devbook.cz => Nové vlákno => Mám za úkol sečíst prvky v poli, ale nevím si s tím rady. Kdo mi to napíše?
Zobrazeno 12 zpráv z 12.