Politechnika Wrocławska niedawno otworzyła Aleję Profesorów. Na otwarciu nie byłem, choć otarłem się o Profesorów…

Politechnika Wrocławska niedawno otworzyła Aleję Profesorów. Na otwarciu nie byłem, choć otarłem się o Profesorów wędrujących na poczęstunek.

Kilka dni później „strzeliłem” sześć panoramek, ale zanim zgłosiłem je Googlowi, zanim zatwierdził, zanim połączyłem je ze sobą. W każdym razie kilka chwil minęło. Zapraszam do wirtualnej wędrówki.

Zaliczenia, zaliczenia…

Osoby, które chcą poprawiać ocenę z laboratorium/projektu umawiają się indywidualnie proponując jakiś termin. Zaliczenia odbywają się w sali 5/02 B1 (na poddaszu, tam gdzie odbywały się zajęcia).

Mój kalendarz dostępny jest na mojej „stronie głównej”.

Jeżeli chodzi o zaliczenia wykładu, ze względu na liczbę osób zainteresowany jestem jednym terminem, w przyszłym tygodniu (29 czerwca — 3 lipca). Gdy nie usłyszę o takim terminie, wyznaczę go sam.

Kilka uwag po kolokwium

Nie sądzę, że ktokolwiek to przeczyta, ale sprawdzanie waszych prac, to prawdziwa mordęga.

  1. Jak przepisujecie od kolegi — przetwarzajcie tekst. Żeby się trochę różnił. Chyba, że nie rozumiecie co przepisujecie (obawiam się, że w większości przypadków tak właśnie było).
  2. Przepisujcie tylko od tych, którzy coś wiedzą.
  3. Sprawdźcie treść zadania. Bo czasami przepisywana treść zupełnie do zadania nie przystaje. Ale czytanie ze zrozumieniem, nie musi być łatwe.
  4. Nie jest prawdą, że po każdym poleceniu if albo else powinny wystąpić nawiasy klamrowe (dotyczy to również forwhile). Jeżeli wykonywane jest tylko jedno polecenie — nawiasów może nie być!
  5. Nie jest prawdą, że void f(int x) nie jest funkcją tylko procedurą. W terminologii języka C jest funkcją, którą czasami (przez analogię do innych języków programowania) nazywa sięprocedurą.
  6. Po raz kolejny zwracam uwagę na operatory (dwuargumentowe) & oraz && i parę | oraz ||. Pierwszy (& to operator logiczny I (AND po angielsku) działający na bitach. Drugi (&&) I (AND po angielsku) działające na całych wartościach. Zatem ’1 & 3’ należy interpretować jako 00000001 & 00000011; wynik ostatniej operacji to 00000001 (operator „wynajduje” bity 1 występujące na tych samych pozycjach w obu liczbach. W przypadku operatora && wartości nie są rozbijane na poszczególne bity tylko interpretowane jako całość: wartość równa zeru to fałsz (False) a różna od zera — prawda (True). I tak przeprowadzane są obliczenia. Gdy i zmienia się od 0 do 9 to 1 & i przyjmuje wartości 0, 1, 0, 1 i tak dalej (zero dla liczb parzystych i 1 dla nieparzystych). W przypadku wyrażenia 1 && i — gdy i jest równe zero — wynik całego wyrażenia jest fałsz (bo prawda (1) AND fałsz (0)), dla pozostałych wartości i będzie prawda ANDprawda czyli prawda. W przypadku operatorów LUB (OR) jest bardzo podobnie.
  7. Jeżeli gdzieś Państwo zobaczą coś takiego cards[2] = cards[3]; to nie interpretujcie tego jako „do tablicy dwuelementowej wpisz tablicę trójelementową” tylko jako „trzeci (choć numerowany od zera) element tablicy cards wstaw w miejsce drugiego (też numerowanego od zera)”.
  8. To: "abcdef" to stała tekstowa. Charakter (typ) tej stałej to „tablica znakowa”. "abcdef"[5] to piąty (licząc od zera) element tej tablicy. Tablica ta zawiera sześć znaków (liter), a jej siódmym elementem jest znak o kodzie ASCII 0. W żadnym wypadku "abcdef"[5] nie jest pytaniem o długość napisu. Choć istotnie, "abcdef"[i], gdy i zmienia się od zera do 5 będzie różne od zera, a "abcdef"[6] będzie równe 0, natomiast ile wyniesie "abcdef"[7] nie bardzo wiadomo. Może być, na przykład tak:

(Jest to wynik działania programu:

Ten plakat Politechnika Wrocławska umieściła w takim miejscu, że trudno się zatrzymać i sfotografować. (Pewno jest i…

Ten plakat Politechnika Wrocławska umieściła w takim miejscu, że trudno się zatrzymać i sfotografować. (Pewno jest i jeszcze gdzie indziej, ale nie zauważyłem.)

Ale przypatrzmy się temu i potraktujmy problem matematycznie:
1. Gdy nie ma szczęścia to jest nieszczęście. 
2. Traktując bardziej formalnie jest jako = otrzymujemy 
nieszczęście = matematyka
cbdo