Podstawy informatyki. Wykład nr 1 ( ) Politechnika Białostocka. - Wydział Elektryczny. dr inŝ. Jarosław Forenc

Wielkość: px
Rozpocząć pokaz od strony:

Download "Podstawy informatyki. Wykład nr 1 ( ) Politechnika Białostocka. - Wydział Elektryczny. dr inŝ. Jarosław Forenc"

Transkrypt

1 Podstawy informatyki Politechnika Białostocka - Wydział Elektryczny Elektrotechnika, semestr II, studia niestacjonarne Rok akademicki 2006/2007 Wykład nr 1 ( )

2 Wykład nr 1 2/34 Dane podstawowe dr inŝ. Jarosław aw Forenc Politechnika Białostocka, Wydział Elektryczny, Katedra Elektrotechniki Teoretycznej i Metrologii ul. Wiejska 45D, Białystok WE jarekf@pb.edu.pl tel. (0-85) konsultacje: Dydaktyka - slajdy prezentowane na wykładzie poniedziałek, godz. 9:00-10:00, WE-204 środa, godz. 10:00-11:00, WE-204 środa, godz. 16:00-17:00, WE-204 piątek, godz. 19:00-20:00, WE-204 (st. zaoczne) sobota, godz. 14:00-15:00, WE-204 (st. zaoczne, co 2-gi zjazd)

3 Wykład nr 1 3/34 Program wykładu 1. Tablice i wskaźniki w języku C. Dynamiczny przydział pamięci. 2. Pliki w języku C. Typy plików, operacje na plikach. 3. Wprowadzenie do metod numerycznych. Błędy w obliczeniach numerycznych. 4. Operacje na wektorach i macierzach. 5. Rozwiązywanie układów równań liniowych: metody dokładne i iteracyjne. 6. Metody poszukiwania pierwiastków funkcji nieliniowych: bisekcji, regula falsi, siecznych. 7. Metody całkowania numerycznego: prostokątów, trapezów, parabol. 8. Algorytmy stosowane w komputerowej analizie obwodów elektrycznych. Środowisko SPICE. 9. Ogólna struktura i zasada działania systemów komputerowych. Klasyfikacja komputerów. System operacyjny.

4 Wykład nr 1 4/34 Literatura (1/2) Język C/C++: 1. B.W. Kernighan, D.M. Ritchie: Język ANSI C. WNT, Warszawa, A. Sopek: W głąb języka C. Helion, Gliwice, 1993 ( 3. J. Grębosz: Symfonia C++ standard. Wydawnictwo Edition 2000, Kraków, K. Barteczko: Praktyczne wprowadzenie do programowania obiektowego w języku C++. Wydawnictwo Lupus, Warszawa, A. Zalewski: Programowanie w językach C i C++ z wykorzystaniem pakietu Borland C++. Wydawnictwo Nakom, Poznań, B. Stroustrup: Język C++. WNT, Warszawa, 2004.

5 Wykład nr 1 5/34 Literatura (2/2) Inne: 1. D. Kincaid, W. Cheney: Analiza numeryczna. WNT, Warszawa, Z. Fortuna, B. Macukow, J. Wąsowski: Metody numeryczne. WNT, Warszawa, B. Baron, Ł. Piątek: Metody numeryczne w C++Builder. Helion, Gliwice, A. Dobrowolski: Pod maską SPICE a. Metody i algorytmy analizy układów elektronicznych. Wydawnictwo BTC, Warszawa, J. Ogrodzki: Komputerowa analiza układów elektronicznych. Wydawnictwo Naukowe PWN, Warszawa, L.O. Chua, Pen-Min Lin: Komputerowa analiza układów elektronicznych: algorytmy i metody obliczeniowe. WNT, Warszawa, 1981.

6 Wykład nr 1 6/34 Wykład a pracownia Wykład Pracownia Tablice i wskaźniki w języku C. Dynamiczny przydział pamięci. Pliki w języku C. Typy plików, operacje na plikach. Wprowadzenie do metod numerycznych. Błędy w obliczeniach numerycznych Operacje na wektorach i macierzach. Rozwiązywanie układów równań liniowych: metody dokładne i iteracyjne. Metody poszukiwania pierwiastków funkcji nieliniowych: bisekcji, regula falsi, siecznych. Metody całkowania numerycznego: prostokątów, trapezów, parabol. Algorytmy stosowane w komputerowej analizie obwodów elektrycznych. Środowisko SPICE. Ogólna struktura i zasada działania systemów komputerowych. Klasyfikacja komputerów. System operacyjny Zajęcia organizacyjne. Środowisko DEV-C++, tworzenie analiza i uruchomianie programów w języku C. Typy, zmienne, stałe, operatory i wyraŝenia arytmetyczne. Operatory relacyjne i logiczne, instrukcje warunkowe oraz sterujące, funkcje w języku C. Typ strukturalny, konstruowanie struktur prostych oraz złoŝonych, dostęp do składowych, wskaźniki do struktur. Tablice jedno- i wielowymiarowe, wskaźniki, operacje na wskaźnikach, dynamiczny przydział pamięci - instrukcje: malloc(), calloc(), free(). Operacje na plikach tekstowych, instrukcje: fscanf(), fprintf(). Operacje na plikach binarnych, instrukcje: fread(), fwrite(). Metody poszukiwania miejsc zerowych funkcji. Metody całkowania numerycznego: metoda prostokątów, trapezów, parabol. Operacje na wektorach i macierzach. Metody rozwiązywania układów równań liniowych.

7 Wykład nr 1 7/34 Zaliczenie wykładu Kolokwium pisemne termin zostanie ustalony pod koniec semestru liczba podejść: min. 2

8 Wykład nr 1 8/34 Plan wykładu nr 1 Tablice w języku C - przypomnienie wiadomości Wskaźniki co to jest wskaźnik? deklaracja wskaźnika operacje na wskaźnikach Wskaźniki a tablice Dynamiczny przydział pamięci funkcje calloc, malloc i free operatory new i delete

9 Wykład nr 1 9/34 Tablice jednowymiarowe tablica jest to ciągły obszar pamięci, w którym umieszczone są elementy tego samego typu int tab[5]; deklarując tablicę musimy podać: typ elementów tablicy, nazwę tablicy oraz liczbę elementów tablicy: średnik rozmiar tablicy nazwa tablicy typ elementów tablicy rozmiar tablicy musi być dodatnią stałą całkowitoliczbową, a ponadto musi to być wartość znana juŝ w fazie kompilacji (nie moŝe to być zmienna) powyŝsza deklaracja definiuje tablicę pięciu elementów typu int, jest to tablica jednowymiarowa, czyli tzw. wektor: kaŝdy element tablicy ma swój numer zwany indeksem, pierwszy element ma indeks 0 (zero), zaś ostatni N-1, gdzie N - rozmiar tablicy jako indeks moŝe występować wyraŝenie, ale w wyniku musi ono dawać liczbę całkowitą nazwa tablicy jest adresem jej pierwszego elementu (o indeksie 0) w pamięci komputera

10 Wykład nr 1 10/34 Tablice jednowymiarowe Odwołanie do elementów tablicy: odwołania do elementów tablicy (odczytanie lub zapisanie wartości) wykonuje się za pomocą dwuargumentowego operatora indeksowania [ ]: Przykład: tab[1]=5; - zapisanie do drugiego elementu tablicy tab wartości 5 x=tab[1]; - odczytanie drugiego elementu z tablicy tab i przypisanie jego wartości zmiennej x przy odwołaniach do elementów tablicy kompilator nie sprawdza, czy piszemy lub czytamy poza obszarem pamięci przydzielonej tablicy, np. int tab[5]; tab[5]=10; - deklaracja tablicy - błąd!!!, nie istnieje element o indeksie 5, ale kompilator nie zasygnalizuje błędu, tylko w obszarze za tablicą zapisze wartość 10

11 Wykład nr 1 11/34 Tablice dwuwymiarowe Deklaracja tablicy dwuwymiarowej: deklarując tablicę dwuwymiarową musimy podać: typ elementów tablicy, nazwę tablicy oraz liczbę wierszy i kolumn tablicy float tab[3][4]; przedstawiona deklaracja definiuje tablicę dwunastu elementów typu float, składającą się z trzech wierszy i czterech kolumn tablica dwuwymiarowa nazywana jest macierzą odwołując się do elementów tablicy dwuwymiarowej musimy podać dwa indeksy: numer wiersza i numer kolumny, na przecięciu których znajduje się dany element średnik liczba kolumn tablicy liczba wierszy tablicy nazwa tablicy typ elementów tablicy Przykład: tab[1][2]=10; x=tab[1][2]; - zapisanie wartości - odczytanie wartości

12 Wykład nr 1 12/34 Inicjalizacja elementów w tablicy po zadeklarowaniu tablicy wartość jej elementów jest nieokreślona inicjalizacja elementów tablicy jest to nadanie wartości jej elementom od razu przy deklaracji inicjalizacja taka polega na umieszczeniu w deklaracji po znaku równości, ujętej w nawiasy klamrowe, listy wartości kolejnych jej elementów, oddzielonych od siebie przecinkami (lista ta moŝe zawierać równieŝ wyraŝenia) Przykład: int a[3]={5,7,1}; int b[2][3]={{3,6,2},{4,1,0}}; int b[2][3]={3,6,2,4,1,0}; obie deklaracje tablicy b oznaczają dokładnie to samo poszczególne wiersze macierzy moŝna wyróŝnić dodatkowymi nawiasami klamrowymi (pierwsza postać)

13 Wykład nr 1 13/34 Inicjalizacja elementów w tablicy tablice moŝna inicjalizować tylko przy deklaracji jeśli wartości podanych w trakcie inicjalizacji jest mniej niŝ wynosi rozmiar tablicy, to pozostałe elementy tablicy wypełniane są zerami Przykład: int b[2][3]={3,6,2,4}; elementy uzupełnione zerami int b[2][3]={0}; - wypełnienie całej tablicy zerami tablica zadeklarowana bez podania rozmiaru, a zainicjowana ma ilość elementów równą ilości inicjatorów: int a[]={2,3,1,4}; jest równowaŝne int a[4]={2,3,1,4};

14 ś ś Podstawy informatyki (st. niestacjonarne, 2006/2007) Wykład nr 1 14/34 Wskaźniki - gdzie juŝ występowa powały? Funkcja scanf: funkcja scanf wymaga podania adresów zmiennych pod którymi będą zapamiętane dane odczytane z klawiatury, np. int a, b; float c; char txt[10]; scanf( %d %d %f %s, &a, &b, &c, txt); Struktury: przy omawianiu struktur wspominane jest, Ŝe jeśli posługujemy się wskaźnikami na struktury, to do odwołania do pól struktury stosujemy operator pośredniego wyboru pola: -> struct punkt { int x, y; } p1, *p2; p2 = &p1; p1.x = 10; /* operator bezpo redniego wyboru pola */ p2->x = 10; /* operator po redniego wyboru pola */

15 Wykład nr 1 15/34 Co to jest wskaźnik? Wskaźnik jest zmienną mogącą zawierać adres obszaru pamięci, a w szczególności adres innej zmiennej (obiektu) Rozpatrzmy następujące deklaracje zmiennych i sposób przechowywania ich w pamięci komputera: int a; float b; char c, d; int tab[4]; int e; double f; wszystkie zmienne przechowywane są w pamięci komputera i zaleŝnie od typu zmiennej zajmują określoną liczbę bajtów kaŝda zmienna oprócz nazwy, której uŝywa programista, ma takŝe adres komputer nie posługuje się nazwami zmiennych tylko ich adresami

16 Wykład nr 1 16/34 Co to jest wskaźnik? Wskaźnik jest zmienną mogącą zawierać adres obszaru pamięci, a w szczególności adres innej zmiennej (obiektu) Rozpatrzmy następujące deklaracje zmiennych i sposób przechowywania ich w pamięci komputera: int a; float b; char c, d; int tab[4]; int e; double f; w powyŝszym przykładzie poszczególne zmienne mają następujące adresy: a 100 (int, 4 bajty) b 104 (float, 4 bajty) c 108 (char, 1 bajt) d 109 (char, 1 bajt) e 126 (int, 4 bajty) f 130 (double, 8 bajtów) tab 110 (tablica, int, 4 4 bajty)

17 Wykład nr 1 17/34 Wskaźniki Deklaracja wskaźnika: adres określa miejsce w pamięci, nie mówi natomiast nic na temat rozmiaru wskazywanego obiektu deklarując wskaźnik (zmienną wskazującą) musimy podać typ obiektu na jaki on wskazuje deklaracja zmiennej wskazującej wygląda tak samo jak deklaracja kaŝdej innej zmiennej, tylko Ŝe jej nazwa poprzedzona jest symbolem gwiazdki (*): typ *nazwa_zmiennej; lub typ* nazwa_zmiennej; Przykład: int *ptr; powyŝszy zapis oznacza deklarację zmiennej wskaźnikowej na typ int mówimy, Ŝe zmienna ptr jest typu: wskaźnik na zmienną typu int, a zatem moŝe przechowywać adresy zmiennych a i e typu int z wcześniejszego przykładu

18 Wykład nr 1 18/34 Wskaźniki do przechowywania adresu zmiennej f typu double trzeba zadeklarować zmienną typu: wskaźnik na zmienną typu double, czyli np. double *ptrd; moŝna konstruować wskaźniki na dane dowolnego typu łącznie z typami wskaźnik na... lub wskaźnik na wskaźnik na... char **wsk; w powyŝszym przykładzie wsk jest typu wskaźnik na wskaźnik na typ char moŝna deklarować tablice wskaźników Uwaga: deklaracja wskaźnika wydziela tylko obszar pamięci dla przechowywania wskaźnika, tj. adresu (dla komputerów PC są to 2 lub 4 bajty, zaleŝnie od tego czy adresy są bliskie - near, czy dalekie - far), nie jest natomiast przydzielany obszar dla danych, na które ma wskazywać wskaźnik

19 Wykład nr 1 19/34 Wskaźniki Przypisywanie wskaźnikom adresów innych zmiennych: adresy zmiennych, które moŝna przypisać wskaźnikom, tworzy się za pomocą jednoargumentowego operatora pobierania adresu & (znanego z funkcji scanf): int a = 10; - deklaracja zmiennej typu int i nadanie jej wartości 10 int *ptr; ptr = &a; - deklaracja wskaźnika na zmienną typu int - przypisanie zmiennej ptr adresu zmiennej a (od tej chwili zmienna ptr wskazuje na zmienną a; a - zmienna typu int, &a - adres zmiennej a) Odwołanie do zmiennej poprzez jej adres: mając adres zmiennej moŝna dostać się do jej wartości uŝywając tzw. operatora wyłuskania (odwołania pośredniego) oznaczanego przez gwiazdkę (*) *ptr = 20; - jest równowaŝne z tym, Ŝe zmiennej a z powyŝszego przykładu przypisujemy wartość 20

20 Wykład nr 1 20/34 Wskaźniki Odwołanie do zmiennej poprzez jej adres: jeśli ptr jest wskaźnikiem na jakiś obiekt, to *ptr jest obiektem (zawartością pamięci pod adresem zawartym w ptr, interpretowaną zgodnie z typem obiektu, na który wskazuje ptr) Przykład: int a = 10; /* a - zmienna typu int */ int *ptr = &a; /* ptr - wskaźnik na zmienną typu int */ int **ptr1 = &ptr; /* ptr1 - wskaźnik na wskaźnik na zmienną typu int */ a = 20; /* przypisanie zmiennej a wartości 20 */ *ptr = 20; /* j.w. */ *(*ptr1) = 20; /* j.w. */ efekt końcowy wykonania trzech ostatnich instrukcji jest taki sam

21 Wykład nr 1 21/34 Wskaźniki Uwaga: zmiennej wskaźnikowej moŝna nadać wartość zerową, co oznacza, Ŝe wskaźnik na nic nie wskazuje - naleŝy stosować wtedy stałą o nazwie NULL int *ptr; ptr = NULL;

22 Wykład nr 1 22/34 Wskaźniki - przykład #include <stdio.h> int main() { int a = 10; /* deklaracja Wartosc zmiennej zmiennej typu int a */ a = 20 int *ptr; /* deklaracja wskaznika na zmienna typu int */ printf("wartosc zmiennej a a = %d\n",a); printf("adres zmiennej a &a = %d\n",&a); ptr = &a; /* zmiennej ptr przypisujemy adres zmiennej a */ printf("adres zmiennej a ptr = %d\n",ptr); printf("wartosci zmiennej a *ptr = %d\n",*ptr); *ptr = 20; /* zmiana wartosci zmiennej a */ printf("wartosci zmiennej a *ptr = %d\n",*ptr); printf("wartosc zmiennej a a = %d\n",a); Wartosc zmiennej a a = 10 Adres zmiennej a &a = Adres zmiennej a ptr = Wartosci zmiennej a *ptr = 10 Wartosci zmiennej a *ptr = 20 } return 0; Przykładowe operacje na wskaźnikach

23 Wykład nr 1 23/34 Wskaźniki Operacje na wskaźnikach: na wskaźnikach dopuszczalne są następujące operacje: przypisywanie wartości innych wskaźników oraz zera (NULL) dodawanie do wartości wskaźnika liczb całkowitych obliczanie róŝnicy wskaźników porównywanie wartości wskaźnika z zerem (wartością stałej NULL) porównywanie wskaźników między sobą przekształcanie wskaźników (konwersje wskaźnikowe) dodanie do wskaźnika lub odjęcie wartości całkowitej 1 oznacza zwiększenie lub zmniejszenie adresu o wartość zaleŝną od tego na jaki typ wskazuje wskaźnik jeśli mamy zadeklarowany wskaźnik: typ *ptr; to wyraŝenie (ptr + n) wskazuje na obszar odległy o n * sizeof(typ) bajtów od adresu zawartego w ptr

24 Wykład nr 1 24/34 Wskaźniki a tablice nazwa tablicy jest adresem pierwszego elementu tablicy int tab[5] = {10,15,37,16,25}; tab - nazwa tablicy będąca adresem jej pierwszego elementu *tab - wartość pierwszego elementu tablicy (10) - równowaŝny zapis: tab[0] *(tab+1) - wartość drugiego elementu tablicy (15) - równowaŝny zapis: tab[1] *(tab+2) - wartość trzeciego elementu tablicy (37) - równowaŝny zapis: tab[2]... ogólnie: tab[i] jest równowaŝne: *(tab+i)

25 Wykład nr 1 25/34 Wskaźniki a tablice w zapisie *(tab+i) nawiasy są konieczne, gdyŝ operator * ma bardzo wysoki priorytet Przykład: int tab[5] = {10,15,37,16,25},x; x = *(tab+2); printf( x = %d,x); /* x = 37 */ x = *tab+2; printf( x = %d,x); /* x = 12 */ x = *(tab+2); jest równowaŝne x = tab[2]; x = *tab+2; jest równowaŝne x = tab[0] + 2;

26 Wykład nr 1 26/34 Dynamiczny przydział pamięci deklaracja tablicy w języku C wymaga, aby jej rozmiar był znany juŝ na etapie kompilacji programu w przypadku, gdy rozmiar tablicy będzie znany dopiero podczas wykonania programu, pamięć naleŝy przydzielić dynamicznie do tego celu słuŝą funkcje dynamicznego przydziału pamięci: calloc malloc i zwalniania pamięci: free działanie powyŝszych funkcji polega na przydzielaniu i zwalnianiu bloków pamięci w obszarze stosu zmiennych dynamicznych

27 Wykład nr 1 27/34 Dynamiczny przydział pamięci CALLOC void *calloc(size_t n, size_t size); stdlib.h funkcja calloc przydziela blok pamięci o rozmiarze n*size (czyli blok pamięci mogący pomieścić tablicę n-elementów podanego rozmiaru size) i zwraca wskaźnik do tego bloku jeśli pamięci nie moŝna przydzielić, to funkcja zwraca wartość NULL przydzielona pamięć jest inicjowana zerami MALLOC void *malloc(size_t size); stdlib.h funkcja malloc przydziela blok pamięci o rozmiarze określonym parametrem size i zwraca wskaźnik do tego bloku jeśli pamięci nie moŝna przydzielić, to funkcja zwraca wartość NULL przydzielona pamięć nie jest inicjowana

28 Wykład nr 1 28/34 Dynamiczny przydział pamięci zwracaną przez funkcje calloc i malloc wartość wskaźnika naleŝy rzutować na właściwy typ, np. przydział pamięci na 10 elementową tablicę elementów typu int: int *tab; tab = (int *) calloc(10,sizeof(int)); /*... */ free(tab); do elementów takiej tablicy odwołujemy się tak samo jak do elementów zwykłej tablicy (ale tylko w przypadku tablic jednowymiarowych!!!) przydzieloną pamięć naleŝy po wykorzystaniu zwolnić funkcją free FREE void *free(void *ptr); stdlib.h funkcja free zwalnia blok pamięci wskazywany parametrem ptr wartość ptr musi być wynikiem wcześniejszego wywołania funkcji calloc lub malloc

29 Wykład nr 1 29/34 Dynamiczny przydział pamięci - przykład Podaj ilosc liczb: 5 #include <stdio.h> #include <stdlib.h> Podaj liczbe nr 1: 1 Podaj liczbe nr 2: 2 int main() Podaj liczbe nr 3: 3 { int *tab, i, n, x; Podaj liczbe nr 4: 4 float suma = 0.0; Podaj liczbe nr 5: 5 Srednia 5 liczb wynosi printf("podaj ilosc liczb: "); scanf("%d",&n); tab = (int *) calloc(n,sizeof(int)); if (tab == NULL) { printf("nie mozna przydzielic pamieci.\n"); exit(-1); } for (i=0; i<n; i++) /* wczytanie liczb */ { printf("podaj liczbe nr %d: ",i+1); scanf("%d",&x); tab[i] = x; } for (i=0; i<n; i++) suma = suma + tab[i]; printf("srednia %d liczb wynosi %f\n",n,suma/n); } free(tab); return 0; Przydział pamięci na n-liczb typu int, wczytanie liczb, obliczenie średniej

30 Wykład nr 1 30/34 Dynamiczny przydział pamięci w programie z poprzedniego slajdu moŝna zrezygnować ze zmiennej x i liczby wczytywać bezpośrednio do tablicy tab - pętla wczytująca liczby będzie miała wtedy postać: for (i=0; i<n; i++) /* wczytanie liczb */ { printf("podaj liczbe nr %d: ",i+1); scanf("%d",&tab[i]); } wczytywanie liczb moŝna zapisać jeszcze w inny sposób ((tab+i) jest adresem i-tego elementu tablicy): for (i=0; i<n; i++) /* wczytanie liczb */ { printf("podaj liczbe nr %d: ",i+1); scanf("%d",(tab+i)); }

31 Wykład nr 1 31/34 Operatory new i delete (C++) Operator new: w najprostszym przypadku zastosowanie operatora new ma postać: typ *ptr = new typ; operator ten alokuje obszar pamięci niezbędny dla przechowywania obiektu typu typ i zwraca wskaźnik na początek tego obszaru jeśli alokacja pamięci nie jest moŝliwa, to zwracana jest wartość NULL typ wskaźnika jest odpowiednio dopasowany do typu obiektu, więc nie są konieczne Ŝadne konwersje wskaźnikowe pamięć przydzielona przez operator new istnieje do zakończenia programu lub do chwili zwolnienia tej pamięci za pomocą operatora delete Operator delete: w najprostszym przypadku operator delete ma postać: delete ptr; gdzie ptr jest wskaźnikiem wskazującym na obiekt stworzony przez new

32 Wykład nr 1 32/34 Operatory new i delete (C++) - przykład #include <stdio.h> *ptr = 10 int main() { int *ptr; ptr = new int; if (ptr == NULL) { printf("blad przydzialu pamieci.\n"); return 1; } *ptr = 10; printf("*ptr = %d\n",*ptr); delete ptr; } return 0; Przydział pamięci operatorem new i zwolnienie operatorem delete

33 Wykład nr 1 33/34 Operatory new i delete (C++) operatory new i delete stosuje się zazwyczaj przy tworzeniu dynamicznych tablic oraz przy tworzeniu dynamicznych struktur danych (stos, kolejka, lista) utworzenie tablicy n elementów typu typ ma postać: typ *ptr = new typ[n] wartością powyŝszego wyraŝenia jest wskaźnik na typ (a nie na tablicę elementów typu typ) jako rozmiar tablicy n moŝna podać dowolne wyraŝenie, a nie tylko wyraŝenie stałe niestety nie moŝna w ten sposób tworzyć dynamicznych tablic wielowymiarowych usuwając tablicę, trzeba podać, Ŝe chodzi o tablicę, a nie o pojedynczy element: delete [] ptr; gdzie ptr jest wskaźnikiem zwróconym przez operator new podczas tworzenia dynamicznej tablicy

34 Wykład nr 1 34/34 Operatory new i delete (C++) - przykład Podaj ilosc liczb: 5 #include <stdio.h> #include <stdlib.h> Podaj liczbe nr 1: 1 Podaj liczbe nr 2: 2 int main() Podaj liczbe nr 3: 3 { int *tab, i, n; Podaj liczbe nr 4: 4 float suma = 0.0; Podaj liczbe nr 5: 5 Srednia 5 liczb wynosi printf("podaj ilosc liczb: "); scanf("%d",&n); tab = new int[n]; if (tab == NULL) { printf("nie mozna przydzielic pamieci.\n"); exit(-1); } for (i=0; i<n; i++) /* wczytanie liczb */ { printf("podaj liczbe nr %d: ",i+1); scanf("%d",&tab[i]); } for (i=0; i<n; i++) suma = suma + tab[i]; printf("srednia %d liczb wynosi %f\n",n,suma/n); } delete [] tab; return 0; Przydział pamięci na n-liczb typu int, wczytanie liczb, obliczenie średniej

Podstawy informatyki 2. Podstawy informatyki 2. Wykład nr 1 ( ) Dane podstawowe. Politechnika Białostocka. - Wydział Elektryczny

Podstawy informatyki 2. Podstawy informatyki 2. Wykład nr 1 ( ) Dane podstawowe. Politechnika Białostocka. - Wydział Elektryczny Wykład nr 1 2/42 Politechnika Białostocka - Wydział Elektryczny Elektrotechnika, semestr II, studia stacjonarne Rok akademicki 2006/2007 Wykład nr 1 (28.02.2007) Dane podstawowe dr inŝ. Jarosław aw Forenc

Bardziej szczegółowo

Spis treści WSKAŹNIKI. DYNAMICZNY PRZYDZIAŁ PAMIĘCI W JĘZYKU C. Informatyka 2. Instrukcja do pracowni specjalistycznej z przedmiotu

Spis treści WSKAŹNIKI. DYNAMICZNY PRZYDZIAŁ PAMIĘCI W JĘZYKU C. Informatyka 2. Instrukcja do pracowni specjalistycznej z przedmiotu Politechnika Białostocka Wydział Elektryczny Katedra Elektrotechniki Teoretycznej i Metrologii Instrukcja do pracowni specjalistycznej z przedmiotu Informatyka 2 Kod przedmiotu: ES1C300 016 (studia stacjonarne)

Bardziej szczegółowo

Spis treści JĘZYK C - WSKAŹNIKI, DYNAMICZNY PRZYDZIAŁ PAMIĘCI. Informatyka 2. Instrukcja do pracowni specjalistycznej z przedmiotu

Spis treści JĘZYK C - WSKAŹNIKI, DYNAMICZNY PRZYDZIAŁ PAMIĘCI. Informatyka 2. Instrukcja do pracowni specjalistycznej z przedmiotu Politechnika Białostocka Wydział Elektryczny Katedra Elektrotechniki Teoretycznej i Metrologii Instrukcja do pracowni specjalistycznej z przedmiotu Informatyka 2 Kod przedmiotu: ES1D300 017 (studia stacjonarne)

Bardziej szczegółowo

Spis treści WSKAŹNIKI. DYNAMICZNY PRZYDZIAŁ PAMIĘCI W JĘZYKU C. Informatyka 2. Instrukcja do pracowni specjalistycznej z przedmiotu

Spis treści WSKAŹNIKI. DYNAMICZNY PRZYDZIAŁ PAMIĘCI W JĘZYKU C. Informatyka 2. Instrukcja do pracowni specjalistycznej z przedmiotu Politechnika Białostocka Wydział Elektryczny Katedra Elektrotechniki Teoretycznej i Metrologii Instrukcja do pracowni specjalistycznej z przedmiotu Informatyka 2 Kod przedmiotu: ES1C300 016 (studia stacjonarne)

Bardziej szczegółowo

dr inż. Jarosław Forenc

dr inż. Jarosław Forenc Informatyka 2 Politechnika Białostocka - Wydział Elektryczny Elektrotechnika, semestr III, studia niestacjonarne I stopnia Rok akademicki 2011/2012 Pracownia nr 1 (14.10.2011) Rok akademicki 2011/2012,

Bardziej szczegółowo

int tab[5]; tab[1]; ciągły obszar pamięci, w którym umieszczone są elementy tego samego typu macierz [ ] - dwuargumentowy operator indeksowania

int tab[5]; tab[1]; ciągły obszar pamięci, w którym umieszczone są elementy tego samego typu macierz [ ] - dwuargumentowy operator indeksowania Rok akademicki 2013/2014, Pracownia nr 10 2/20 Informatyka 1 Tablica elementów ciągły obszar pamięci, w którym umieszczone są elementy tego samego typu Politechnika Białostocka - Wydział Elektryczny Elektrotechnika,

Bardziej szczegółowo

Dynamiczny przydział pamięci w języku C. Dynamiczne struktury danych. dr inż. Jarosław Forenc. Metoda 1 (wektor N M-elementowy)

Dynamiczny przydział pamięci w języku C. Dynamiczne struktury danych. dr inż. Jarosław Forenc. Metoda 1 (wektor N M-elementowy) Rok akademicki 2012/2013, Wykład nr 2 2/25 Plan wykładu nr 2 Informatyka 2 Politechnika Białostocka - Wydział Elektryczny Elektrotechnika, semestr III, studia niestacjonarne I stopnia Rok akademicki 2012/2013

Bardziej szczegółowo

KURS C/C++ WYKŁAD 6. Wskaźniki

KURS C/C++ WYKŁAD 6. Wskaźniki Wskaźniki KURS C/C++ WYKŁAD 6 Każda zmienna ma unikalny adres wskazujący początkowy obszar pamięci zajmowany przez tą zmienną. Ilość pamięci zajmowanej przez zmienną zależy od typu zmiennej. Adres można

Bardziej szczegółowo

Temat: Dynamiczne przydzielanie i zwalnianie pamięci. Struktura listy operacje wstawiania, wyszukiwania oraz usuwania danych.

Temat: Dynamiczne przydzielanie i zwalnianie pamięci. Struktura listy operacje wstawiania, wyszukiwania oraz usuwania danych. Temat: Dynamiczne przydzielanie i zwalnianie pamięci. Struktura listy operacje wstawiania, wyszukiwania oraz usuwania danych. 1. Rodzaje pamięci używanej w programach Pamięć komputera, dostępna dla programu,

Bardziej szczegółowo

Spis treści JĘZYK C - TABLICE JEDNOWYMIAROWE. Informatyka 1. Instrukcja do pracowni specjalistycznej z przedmiotu. Numer ćwiczenia INF05Z

Spis treści JĘZYK C - TABLICE JEDNOWYMIAROWE. Informatyka 1. Instrukcja do pracowni specjalistycznej z przedmiotu. Numer ćwiczenia INF05Z Politechnika Białostocka Wydział Elektryczny Katedra Elektrotechniki Teoretycznej i Metrologii Instrukcja do pracowni specjalistycznej z przedmiotu Informatyka 1 Kod przedmiotu: EZ1C200 010 (studia niestacjonarne)

Bardziej szczegółowo

Informatyka 2. Informatyka 2. Wykład nr 1 (04.10.2008) Dane podstawowe. - Wydział Elektryczny. Politechnika Białostocka. Program wykładu (1/2)

Informatyka 2. Informatyka 2. Wykład nr 1 (04.10.2008) Dane podstawowe. - Wydział Elektryczny. Politechnika Białostocka. Program wykładu (1/2) Rok akademicki 2008/2009, Wykład nr 1 2/25 Dane podstawowe Informatyka 2 Politechnika Białostocka - Wydział Elektryczny Elektrotechnika, semestr III, studia niestacjonarne I stopnia (zaoczne) Rok akademicki

Bardziej szczegółowo

Lab 9 Podstawy Programowania

Lab 9 Podstawy Programowania Lab 9 Podstawy Programowania (Kaja.Gutowska@cs.put.poznan.pl) Wszystkie kody/fragmenty kodów dostępne w osobnym pliku.txt. Materiały pomocnicze: Wskaźnik to specjalny rodzaj zmiennej, w której zapisany

Bardziej szczegółowo

Informatyka 1. Plan dzisiejszych zajęć. zajęcia nr 1. Elektrotechnika, semestr II rok akademicki 2008/2009

Informatyka 1. Plan dzisiejszych zajęć. zajęcia nr 1. Elektrotechnika, semestr II rok akademicki 2008/2009 Informatyka 1 zajęcia nr 1 Elektrotechnika, semestr II rok akademicki 2008/2009 mgr inż.. Paweł Myszkowski Plan dzisiejszych zajęć 1. Organizacja laboratorium przedmiotu 2. Algorytmy i sposoby ich opisu

Bardziej szczegółowo

Wykład 1: Wskaźniki i zmienne dynamiczne

Wykład 1: Wskaźniki i zmienne dynamiczne Programowanie obiektowe Wykład 1: Wskaźniki i zmienne dynamiczne 1 dr Artur Bartoszewski - Programowanie obiektowe, sem. 1I- WYKŁAD Podstawy programowania w C++ Wskaźniki 2 dr Artur Bartoszewski - Programowanie

Bardziej szczegółowo

Co to jest sterta? Sterta (ang. heap) to obszar pamięci udostępniany przez system operacyjny wszystkim działającym programom (procesom).

Co to jest sterta? Sterta (ang. heap) to obszar pamięci udostępniany przez system operacyjny wszystkim działającym programom (procesom). Zarządzanie pamięcią Pamięć: stos i sterta Statyczny i dynamiczny przydział pamięci Funkcje ANSI C do zarządzania pamięcią Przykłady: Dynamiczna tablica jednowymiarowa Dynamiczna tablica dwuwymiarowa 154

Bardziej szczegółowo

Wskaźniki. Przemysław Gawroński D-10, p marca Wykład 2. (Wykład 2) Wskaźniki 8 marca / 17

Wskaźniki. Przemysław Gawroński D-10, p marca Wykład 2. (Wykład 2) Wskaźniki 8 marca / 17 Wskaźniki Przemysław Gawroński D-10, p. 234 Wykład 2 8 marca 2019 (Wykład 2) Wskaźniki 8 marca 2019 1 / 17 Outline 1 Wskaźniki 2 Tablice a wskaźniki 3 Dynamiczna alokacja pamięci (Wykład 2) Wskaźniki 8

Bardziej szczegółowo

Wskaźniki i dynamiczna alokacja pamięci. Spotkanie 4. Wskaźniki. Dynamiczna alokacja pamięci. Przykłady

Wskaźniki i dynamiczna alokacja pamięci. Spotkanie 4. Wskaźniki. Dynamiczna alokacja pamięci. Przykłady Wskaźniki i dynamiczna alokacja pamięci. Spotkanie 4 Dr inż. Dariusz JĘDRZEJCZYK Wskaźniki Dynamiczna alokacja pamięci Przykłady 11/3/2016 AGH, Katedra Informatyki Stosowanej i Modelowania 2 Wskaźnik to

Bardziej szczegółowo

Wstęp do wskaźników w języku ANSI C

Wstęp do wskaźników w języku ANSI C Wstęp do wskaźników w języku ANSI C / Materiał dydaktyczny pomocniczy do przedmiotu Informatyka sem.iii kier. Elektrotechnika/ 1. Wprowadzenie W języku ANSI C dla każdego typu X (wbudowanego, pochodnego,

Bardziej szczegółowo

Język C zajęcia nr 11. Funkcje

Język C zajęcia nr 11. Funkcje Język C zajęcia nr 11 Funkcje W języku C idea podprogramów realizowana jest wyłącznie poprzez definiowanie i wywołanie funkcji. Każda funkcja musi być przed wywołaniem zadeklarowana. Deklaracja funkcji

Bardziej szczegółowo

DYNAMICZNE PRZYDZIELANIE PAMIECI

DYNAMICZNE PRZYDZIELANIE PAMIECI DYNAMICZNE PRZYDZIELANIE PAMIECI Pamięć komputera, dostępna dla programu, dzieli się na cztery obszary: kod programu, dane statyczne ( np. stałe i zmienne globalne programu), dane automatyczne zmienne

Bardziej szczegółowo

dr inż. Jarosław Forenc

dr inż. Jarosław Forenc Informatyka 2 Politechnika Białostocka - Wydział Elektryczny semestr III, studia stacjonarne I stopnia Rok akademicki 2015/2016 Pracownia nr 1 (21/23.09.2015) Rok akademicki 2015/2016, Pracownia nr 1 2/22

Bardziej szczegółowo

Podstawy programowania. Wykład 6 Wskaźniki. Krzysztof Banaś Podstawy programowania 1

Podstawy programowania. Wykład 6 Wskaźniki. Krzysztof Banaś Podstawy programowania 1 Podstawy programowania. Wykład 6 Wskaźniki Krzysztof Banaś Podstawy programowania 1 Adresy zmiennych Język C pozwala na operowanie adresami w pamięci stąd, między innymi, kwalifikowanie C jako języka relatywnie

Bardziej szczegółowo

Wskaźniki w C. Anna Gogolińska

Wskaźniki w C. Anna Gogolińska Wskaźniki w C Anna Gogolińska Zmienne Zmienną w C można traktować jako obszar w pamięci etykietowany nazwą zmiennej i zawierający jej wartość. Przykład: kod graficznie int a; a a = 3; a 3 Wskaźniki Wskaźnik

Bardziej szczegółowo

TABLICE W JĘZYKU C/C++ typ_elementu nazwa_tablicy [wymiar_1][wymiar_2]... [wymiar_n] ;

TABLICE W JĘZYKU C/C++ typ_elementu nazwa_tablicy [wymiar_1][wymiar_2]... [wymiar_n] ; Ogólna postać definicji tablicy: TABLICE W JĘZYKU C/C++ typ_elementu nazwa_tablicy [wymiar_1][wymiar_2]... [wymiar_n] ; np. int tablica [ 10 ]; // 10-cio elementowa tablica liczb całkowitych char tekst

Bardziej szczegółowo

Wskaźniki. Informatyka

Wskaźniki. Informatyka Materiały Wskaźniki Informatyka Wskaźnik z punktu widzenia programisty jest grupą komórek pamięci (rozmiar wskaźnika zależy od architektury procesora, najczęściej są to dwa lub cztery bajty ), które mogą

Bardziej szczegółowo

// Liczy srednie w wierszach i kolumnach tablicy "dwuwymiarowej" // Elementy tablicy są generowane losowo #include <stdio.h> #include <stdlib.

// Liczy srednie w wierszach i kolumnach tablicy dwuwymiarowej // Elementy tablicy są generowane losowo #include <stdio.h> #include <stdlib. Wykład 10 Przykłady różnych funkcji (cd) - przetwarzanie tablicy tablic (tablicy "dwuwymiarowej") - sortowanie przez "selekcję" Dynamiczna alokacja pamięci 1 // Liczy srednie w wierszach i kolumnach tablicy

Bardziej szczegółowo

> C++ dynamiczna alokacja/rezerwacja/przydział pamięci. Dane: Iwona Polak. Uniwersytet Śląski Instytut Informatyki

> C++ dynamiczna alokacja/rezerwacja/przydział pamięci. Dane: Iwona Polak. Uniwersytet Śląski Instytut Informatyki > C++ dynamiczna alokacja/rezerwacja/przydział pamięci Dane: Iwona Polak iwona.polak@us.edu.pl Uniwersytet Śląski Instytut Informatyki 1429536600 > Dzisiejsze zajęcia sponsorują słówka: new oraz delete

Bardziej szczegółowo

Stałe, tablice dynamiczne i wielowymiarowe

Stałe, tablice dynamiczne i wielowymiarowe Stałe, tablice dynamiczne i wielowymiarowe tylko do odczytu STAŁE - CONST tablice: const int dni_miesiaca[12]=31,28,31,30,31,30,31,31,30,31,30,31; const słowo kluczowe const sprawia, że wartość zmiennej

Bardziej szczegółowo

wykład III uzupełnienie notatek: dr Jerzy Białkowski Programowanie C/C++ Język C - zarządzanie pamięcią, struktury,

wykład III uzupełnienie notatek: dr Jerzy Białkowski Programowanie C/C++ Język C - zarządzanie pamięcią, struktury, , Programowanie, uzupełnienie notatek: dr Jerzy Białkowski , 1 2 3 4 , Wczytywanie liczb , Wczytywanie liczb 1 #include 2 #include < s t d l i b. h> 3 4 int main ( ) { 5 int rozmiar, numer

Bardziej szczegółowo

Spis treści JĘZYK C - TABLICE DWUWYMIAROWE, OPERACJE NA TABLICACH. Metodyki i techniki programowania

Spis treści JĘZYK C - TABLICE DWUWYMIAROWE, OPERACJE NA TABLICACH. Metodyki i techniki programowania Politechnika Białostocka Wydział Elektryczny Katedra Elektrotechniki Teoretycznej i Metrologii Instrukcja do pracowni specjalistycznej z przedmiotu Metodyki i techniki programowania Kod przedmiotu: TS1C200

Bardziej szczegółowo

Strona główna. Strona tytułowa. Programowanie. Spis treści. Sobera Jolanta 16.09.2006. Strona 1 z 26. Powrót. Full Screen. Zamknij.

Strona główna. Strona tytułowa. Programowanie. Spis treści. Sobera Jolanta 16.09.2006. Strona 1 z 26. Powrót. Full Screen. Zamknij. Programowanie Sobera Jolanta 16.09.2006 Strona 1 z 26 1 Wprowadzenie do programowania 4 2 Pierwsza aplikacja 5 3 Typy danych 6 4 Operatory 9 Strona 2 z 26 5 Instrukcje sterujące 12 6 Podprogramy 15 7 Tablice

Bardziej szczegółowo

Programowanie w C++ Wykład 5. Katarzyna Grzelak. 26 marca kwietnia K.Grzelak (Wykład 1) Programowanie w C++ 1 / 40

Programowanie w C++ Wykład 5. Katarzyna Grzelak. 26 marca kwietnia K.Grzelak (Wykład 1) Programowanie w C++ 1 / 40 Programowanie w C++ Wykład 5 Katarzyna Grzelak 26 marca 2018 9 kwietnia 2018 K.Grzelak (Wykład 1) Programowanie w C++ 1 / 40 Pojęcia z poprzedniego wykładu Podział programu na funkcje podział na niezależne

Bardziej szczegółowo

Dynamiczny przydział pamięci (język C) Dynamiczne struktury danych. Sortowanie. Klasyfikacja algorytmów sortowania. Algorytmy sortowania

Dynamiczny przydział pamięci (język C) Dynamiczne struktury danych. Sortowanie. Klasyfikacja algorytmów sortowania. Algorytmy sortowania Rok akademicki 2010/2011, Wykład nr 4 2/50 Plan wykładu nr 4 Informatyka 2 Politechnika Białostocka - Wydział Elektryczny Elektrotechnika, semestr III, studia niestacjonarne I stopnia Rok akademicki 2010/2011

Bardziej szczegółowo

if (warunek) instrukcja1; if (warunek) instrukcja1; else instrukcja2; a > b - a większe od b if (warunek) instrukcja1; a <= b - a mniejsze lub równe b

if (warunek) instrukcja1; if (warunek) instrukcja1; else instrukcja2; a > b - a większe od b if (warunek) instrukcja1; a <= b - a mniejsze lub równe b Rok akademicki 2012/2013, Pracownia nr 4 2/17 Informatyka 1 Instrukcja warunkowa if prawda instrukcja1 warunek fałsz Politechnika Białostocka - Wydział Elektryczny Elektrotechnika, semestr II, studia stacjonarne

Bardziej szczegółowo

Podstawy programowania komputerów

Podstawy programowania komputerów Podstawy programowania komputerów Wykład 10: Sterowanie pamięcią w C Pamięć na stosie!każdy program napisany w języku C ma dostęp do dwóch obszarów pamięci - stosu i sterty, w których może być przechowywana

Bardziej szczegółowo

Programowanie w języku C++

Programowanie w języku C++ Programowanie w języku C++ Część siódma Autor Roman Simiński Kontakt roman.siminski@us.edu.pl www.us.edu.pl/~siminski Niniejsze opracowanie zawiera skrót treści wykładu, lektura tych materiałów nie zastąpi

Bardziej szczegółowo

Podstawy programowania w języku C++

Podstawy programowania w języku C++ Podstawy programowania w języku C++ Część ósma Zmienne wskaźnikowe koncepcja, podstawowe zastosowania Autor Roman Simiński Kontakt roman.siminski@us.edu.pl www.us.edu.pl/~siminski Niniejsze opracowanie

Bardziej szczegółowo

Podstawy programowania. Wykład: 12. Struktury, unie, pola bitowe. dr Artur Bartoszewski -Podstawy programowania, sem 1 - WYKŁAD

Podstawy programowania. Wykład: 12. Struktury, unie, pola bitowe. dr Artur Bartoszewski -Podstawy programowania, sem 1 - WYKŁAD Podstawy programowania Wykład: 12 Struktury, unie, pola bitowe 1 dr Artur Bartoszewski -Podstawy programowania, sem 1 - WYKŁAD Podstawy programowania Struktury 2 Struktury Struktury to złożone typy danych

Bardziej szczegółowo

Programowanie obiektowe W3

Programowanie obiektowe W3 Programowanie obiektowe W3 Przegląd typów strukturalnych w C++ : tablice statyczne i dynamiczne Dr hab. inż. Lucyna Leniowska, prof. UR Zakład Mechatroniki, Automatyki i Optoelektroniki Typy złożone: tablice

Bardziej szczegółowo

ZASADY PROGRAMOWANIA KOMPUTERÓW

ZASADY PROGRAMOWANIA KOMPUTERÓW POLITECHNIKA WARSZAWSKA Instytut Automatyki i i Robotyki ZASADY PROGRAMOWANIA KOMPUTERÓW Język Język programowania: C/C++ Środowisko programistyczne: C++Builder 6 Wykład 9.. Wskaźniki i i zmienne dynamiczne.

Bardziej szczegółowo

Podstawy programowania skrót z wykładów:

Podstawy programowania skrót z wykładów: Podstawy programowania skrót z wykładów: // komentarz jednowierszowy. /* */ komentarz wielowierszowy. # include dyrektywa preprocesora, załączająca biblioteki (pliki nagłówkowe). using namespace

Bardziej szczegółowo

Spis treści JĘZYK C - TABLICE DWU- I WIELOWYMIAROWE, OPERACJE NA TABLICACH. Informatyka 2. Instrukcja do pracowni specjalistycznej z przedmiotu

Spis treści JĘZYK C - TABLICE DWU- I WIELOWYMIAROWE, OPERACJE NA TABLICACH. Informatyka 2. Instrukcja do pracowni specjalistycznej z przedmiotu Politechnika Białostocka Wydział Elektryczny Katedra Elektrotechniki Teoretycznej i Metrologii Instrukcja do pracowni specjalistycznej z przedmiotu Informatyka 2 Kod przedmiotu: ES1D300 017 (studia stacjonarne)

Bardziej szczegółowo

Język C, tablice i funkcje (laboratorium)

Język C, tablice i funkcje (laboratorium) Język C, tablice i funkcje (laboratorium) Opracował: Tomasz Mączka (tmaczka@kia.prz.edu.pl) Wstęp (tablice) Tablica to uporządkowany ciąg elementów tego samego typu, zajmujących ciągły obszar pamięci.

Bardziej szczegółowo

Tablice (jedno i wielowymiarowe), łańcuchy znaków

Tablice (jedno i wielowymiarowe), łańcuchy znaków Tablice (jedno i wielowymiarowe), łańcuchy znaków wer. 8 z drobnymi modyfikacjami! Wojciech Myszka Katedra Mechaniki i Inżynierii Materiałowej 2017-04-07 09:35:32 +0200 Zmienne Przypomnienie/podsumowanie

Bardziej szczegółowo

Wstęp do programowania INP001213Wcl rok akademicki 2018/19 semestr zimowy. Wykład 4. Karol Tarnowski A-1 p.

Wstęp do programowania INP001213Wcl rok akademicki 2018/19 semestr zimowy. Wykład 4. Karol Tarnowski A-1 p. Wstęp do programowania INP001213Wcl rok akademicki 2018/19 semestr zimowy Wykład 4 Karol Tarnowski karol.tarnowski@pwr.edu.pl A-1 p. 411B Plan prezentacji Tablice Wskaźniki Adresy pamięci Operator adresu

Bardziej szczegółowo

Powyższe wyrażenie alokuje 200 lub 400 w zależności od rozmiaru int w danym systemie. Wskaźnik wskazuje na adres pierwszego bajtu pamięci.

Powyższe wyrażenie alokuje 200 lub 400 w zależności od rozmiaru int w danym systemie. Wskaźnik wskazuje na adres pierwszego bajtu pamięci. 1. Tablice dynamiczne Początkowa zadeklarowana wielkość tablicy czasami może okazać niewystarczająca, lub nadmierna. Dynamiczna alokacja pamięci wykorzystywana jest w celu otrzymania bądź zwolnienia pamięci

Bardziej szczegółowo

Niezwykłe tablice Poznane typy danych pozwalają przechowywać pojedyncze liczby. Dzięki tablicom zgromadzimy wiele wartości w jednym miejscu.

Niezwykłe tablice Poznane typy danych pozwalają przechowywać pojedyncze liczby. Dzięki tablicom zgromadzimy wiele wartości w jednym miejscu. Część XIX C++ w Każda poznana do tej pory zmienna może przechowywać jedną liczbę. Jeśli zaczniemy pisać bardziej rozbudowane programy, okaże się to niewystarczające. Warto więc poznać zmienne, które mogą

Bardziej szczegółowo

Temat 1: Podstawowe pojęcia: program, kompilacja, kod

Temat 1: Podstawowe pojęcia: program, kompilacja, kod Temat 1: Podstawowe pojęcia: program, kompilacja, kod wynikowy. Przykłady najprostszych programów. Definiowanie zmiennych. Typy proste. Operatory: arytmetyczne, przypisania, inkrementacji, dekrementacji,

Bardziej szczegółowo

Spis treści JĘZYK C - TABLICE DWUWYMIAROWE, OPERACJE NA TABLICACH. Informatyka 1. Instrukcja do pracowni specjalistycznej z przedmiotu

Spis treści JĘZYK C - TABLICE DWUWYMIAROWE, OPERACJE NA TABLICACH. Informatyka 1. Instrukcja do pracowni specjalistycznej z przedmiotu Politechnika Białostocka Wydział Elektryczny Katedra Elektrotechniki Teoretycznej i Metrologii Instrukcja do pracowni specjalistycznej z przedmiotu Informatyka 1 Kod przedmiotu: ES1C200 009 (studia stacjonarne)

Bardziej szczegółowo

Podstawy Programowania C++

Podstawy Programowania C++ Wykład 3 - podstawowe konstrukcje Instytut Automatyki i Robotyki Warszawa, 2014 Wstęp Plan wykładu Struktura programu, instrukcja przypisania, podstawowe typy danych, zapis i odczyt danych, wyrażenia:

Bardziej szczegółowo

Wskaźniki. nie są konieczne, ale dają językowi siłę i elastyczność są języki w których nie używa się wskaźników typ wskaźnikowy typ pochodny:

Wskaźniki. nie są konieczne, ale dają językowi siłę i elastyczność są języki w których nie używa się wskaźników typ wskaźnikowy typ pochodny: Wskaźniki nie są konieczne, ale dają językowi siłę i elastyczność są języki w których nie używa się wskaźników typ wskaźnikowy typ pochodny: typ nw; /* definicja zmiennej nw typu typ */ typ *w_nw; /* definicja

Bardziej szczegółowo

Podstawy algorytmiki i programowania - wykład 4 C-struktury

Podstawy algorytmiki i programowania - wykład 4 C-struktury 1 Podstawy algorytmiki i programowania - wykład 4 C-struktury Treści prezentowane w wykładzie zostały oparte o: S. Prata, Język C++. Szkoła programowania. Wydanie VI, Helion, 2012 www.cplusplus.com Jerzy

Bardziej szczegółowo

Wykład 4: Klasy i Metody

Wykład 4: Klasy i Metody Wykład 4: Klasy i Metody Klasa Podstawa języka. Każde pojęcie które chcemy opisać w języku musi być zawarte w definicji klasy. Klasa definiuje nowy typ danych, których wartościami są obiekty: klasa to

Bardziej szczegółowo

Tablice, funkcje - wprowadzenie

Tablice, funkcje - wprowadzenie Tablice, funkcje - wprowadzenie Przemysław Gawroński D-10, p. 234 Wykład 5 25 marca 2019 (Wykład 5) Tablice, funkcje - wprowadzenie 25 marca 2019 1 / 12 Outline 1 Tablice jednowymiarowe 2 Funkcje (Wykład

Bardziej szczegółowo

Zmienne i struktury dynamiczne

Zmienne i struktury dynamiczne Zmienne i struktury dynamiczne Zmienne dynamiczne są to zmienne, które tworzymy w trakcie działania programu za pomocą operatora new. Usuwa się je operatorem delete. Czas ich występowania w programie jest

Bardziej szczegółowo

Wskaźniki. Programowanie Proceduralne 1

Wskaźniki. Programowanie Proceduralne 1 Wskaźniki Programowanie Proceduralne 1 Adresy zmiennych Sterta 1 #include 2 3 int a = 2 ; 4 5 int main ( ) 6 { 7 int b = 3 ; 8 9 printf ( " adres zmiennej a %p\n", &a ) ; 10 printf ( " adres

Bardziej szczegółowo

METODY I JĘZYKI PROGRAMOWANIA PROGRAMOWANIE STRUKTURALNE. Wykład 02

METODY I JĘZYKI PROGRAMOWANIA PROGRAMOWANIE STRUKTURALNE. Wykład 02 METODY I JĘZYKI PROGRAMOWANIA PROGRAMOWANIE STRUKTURALNE Wykład 02 NAJPROSTSZY PROGRAM /* (Prawie) najprostszy przykład programu w C */ /*==================*/ /* Między tymi znaczkami można pisać, co się

Bardziej szczegółowo

Spis treści JĘZYK C - PRZEKAZYWANIE PARAMETRÓW DO FUNKCJI, REKURENCJA. Informatyka 1. Instrukcja do pracowni specjalistycznej z przedmiotu

Spis treści JĘZYK C - PRZEKAZYWANIE PARAMETRÓW DO FUNKCJI, REKURENCJA. Informatyka 1. Instrukcja do pracowni specjalistycznej z przedmiotu Politechnika Białostocka Wydział Elektryczny Katedra Elektrotechniki Teoretycznej i Metrologii Instrukcja do pracowni specjalistycznej z przedmiotu Informatyka 1 Kod przedmiotu: EZ1C200 010 (studia niestacjonarne)

Bardziej szczegółowo

Laboratorium nr 9. Temat: Wskaźniki, referencje, dynamiczny przydział pamięci, tablice dynamiczne. Zakres laboratorium:

Laboratorium nr 9. Temat: Wskaźniki, referencje, dynamiczny przydział pamięci, tablice dynamiczne. Zakres laboratorium: Laboratorium nr 9 Temat: Wskaźniki, referencje, dynamiczny przydział pamięci, tablice dynamiczne. Zakres laboratorium: wskaźniki referencje zastosowanie wskaźników wobec tablic dynamiczny przydział pamięci,

Bardziej szczegółowo

Spis treści JĘZYK C - PRZEKAZYWANIE PARAMETRÓW DO FUNKCJI, REKURENCJA. Informatyka 1. Instrukcja do pracowni specjalistycznej z przedmiotu

Spis treści JĘZYK C - PRZEKAZYWANIE PARAMETRÓW DO FUNKCJI, REKURENCJA. Informatyka 1. Instrukcja do pracowni specjalistycznej z przedmiotu Politechnika Białostocka Wydział Elektryczny Katedra Elektrotechniki Teoretycznej i Metrologii Instrukcja do pracowni specjalistycznej z przedmiotu Informatyka 1 Kod przedmiotu: EZ1C200 010 (studia niestacjonarne)

Bardziej szczegółowo

Języki i metodyka programowania. Wskaźniki i tablice.

Języki i metodyka programowania. Wskaźniki i tablice. Wskaźniki i tablice. Zmienna1 Zmienna2 0 1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 Zmienna to fragment pamięci o określonym rozmiarze identyfikowany za pomocą nazwy, w którym może być przechowywana

Bardziej szczegółowo

Zmienne, stałe i operatory

Zmienne, stałe i operatory Zmienne, stałe i operatory Przemysław Gawroński D-10, p. 234 Wykład 2 4 marca 2019 (Wykład 2) Zmienne, stałe i operatory 4 marca 2019 1 / 21 Outline 1 Zmienne 2 Stałe 3 Operatory (Wykład 2) Zmienne, stałe

Bardziej szczegółowo

Uzupełnienie dot. przekazywania argumentów

Uzupełnienie dot. przekazywania argumentów Uzupełnienie dot. przekazywania argumentów #include #include struct nowa { int f; char line[20000]; int k; } reprezentant; int main() { void funkcja7( struct nowa x); reprezentant.k=17;

Bardziej szczegółowo

Język ANSI C tablice wielowymiarowe

Język ANSI C tablice wielowymiarowe Język ANSI C tablice wielowymiarowe Gdy tablica wielowymiarowa jest parametrem funkcji, to w standardzie ANSI C konieczne jest podanie wszystkich wymiarów poza pierwszym. Przykład. Napisać program wczytujący

Bardziej szczegółowo

6 Przygotował: mgr inż. Maciej Lasota

6 Przygotował: mgr inż. Maciej Lasota Laboratorium nr 6 1/5 Język C Instrukcja laboratoryjna Temat: Wskaźniki. 6 Przygotował: mgr inż. Maciej Lasota 1) Wskaźniki. Wskaźniki (zmienne wskaźnikowe) stanowią jedno z fundamentalnych pojęć języka

Bardziej szczegółowo

tablica: dane_liczbowe

tablica: dane_liczbowe TABLICE W JĘZYKU C/C++ tablica: dane_liczbowe float dane_liczbowe[5]; dane_liczbowe[0]=12.5; dane_liczbowe[1]=-0.2; dane_liczbowe[2]= 8.0;... 12.5-0.2 8.0...... 0 1 2 3 4 indeksy/numery elementów Tablica

Bardziej szczegółowo

Język C, tablice i funkcje (laboratorium, EE1-DI)

Język C, tablice i funkcje (laboratorium, EE1-DI) Język C, tablice i funkcje (laboratorium, EE1-DI) Opracował: Tomasz Mączka (tmaczka@kia.prz.edu.pl) Wstęp (tablice) Tablica to uporządkowany ciąg elementów tego samego typu, zajmujących ciągły obszar pamięci.

Bardziej szczegółowo

Wykład 8: klasy cz. 4

Wykład 8: klasy cz. 4 Programowanie obiektowe Wykład 8: klasy cz. 4 Dynamiczne tworzenie obiektów klas Składniki statyczne klas Konstruktor i destruktory c.d. 1 dr Artur Bartoszewski - Programowanie obiektowe, sem. 1I- WYKŁAD

Bardziej szczegółowo

IX. Wskaźniki.(3 godz.)

IX. Wskaźniki.(3 godz.) Opracowała: dr inż. Anna Dubowicka Uczelniane Centrum Komputerowe PK IX. Wskaźniki.(3 godz.) Wskaźnik jest zmienną, która zawiera adres innej. 1. Definiowanie wskaźników. typ * nazwa ; gdzie: znak * informuje

Bardziej szczegółowo

Tablice, funkcje, wskaźniki - wprowadzenie

Tablice, funkcje, wskaźniki - wprowadzenie Tablice, funkcje, wskaźniki - wprowadzenie Przemysław Gawroński D-10, p. 234 Wykład 4 19 listopada 2018 (Wykład 4) Tablice, funkcje, wskaźniki - wprowadzenie 19 listopada 2018 1 / 37 Outline 1 Tablice

Bardziej szczegółowo

4. Tablica dwuwymiarowa to jednowymiarowa tablica wskaźników do jednowymiarowych tablic danego typu.

4. Tablica dwuwymiarowa to jednowymiarowa tablica wskaźników do jednowymiarowych tablic danego typu. Języki i paradygmaty programowania 1 studia stacjonarne 2018/19 Lab 6. Tablice znakowe o dwóch indeksach, przekazywanie tablic do funkcji cd., dynamiczna alokacja pamięci, funkcje przetwarzające ciągi

Bardziej szczegółowo

1 Wskaźniki i zmienne dynamiczne, instrukcja przed zajęciami

1 Wskaźniki i zmienne dynamiczne, instrukcja przed zajęciami 1 Wskaźniki i zmienne dynamiczne, instrukcja przed zajęciami Celem tych zajęć jest zrozumienie i oswojenie z technikami programowania przy pomocy wskaźników w języku C++. Proszę przeczytać rozdział 8.

Bardziej szczegółowo

dr inż. Jarosław Forenc

dr inż. Jarosław Forenc Informatyka 1 Politechnika Białostocka - Wydział Elektryczny Elektrotechnika, semestr II, studia stacjonarne I stopnia Rok akademicki 2014/2015 Pracownia nr 7 (10/20.04.2015) dr inż. Jarosław Forenc Rok

Bardziej szczegółowo

Spis treści JĘZYK C - OPERATORY RELACYJNE I LOGICZNE, WYRAŻENIA LOGICZNE, INSTRUKCJA WARUNKOWA IF. Informatyka 1

Spis treści JĘZYK C - OPERATORY RELACYJNE I LOGICZNE, WYRAŻENIA LOGICZNE, INSTRUKCJA WARUNKOWA IF. Informatyka 1 Politechnika Białostocka Wydział Elektryczny Katedra Elektrotechniki Teoretycznej i Metrologii Instrukcja do pracowni specjalistycznej z przedmiotu Informatyka 1 Kod przedmiotu: ES1C200 009 (studia stacjonarne)

Bardziej szczegółowo

Tablice i struktury. czyli złożone typy danych. Programowanie Proceduralne 1

Tablice i struktury. czyli złożone typy danych. Programowanie Proceduralne 1 Tablice i struktury czyli złożone typy danych. Programowanie Proceduralne 1 Tablica przechowuje elementy tego samego typu struktura jednorodna, homogeniczna Elementy identyfikowane liczbami (indeksem).

Bardziej szczegółowo

Podstawy informatyki. Elektrotechnika I rok. Język C++ Operacje na danych - wskaźniki Instrukcja do ćwiczenia

Podstawy informatyki. Elektrotechnika I rok. Język C++ Operacje na danych - wskaźniki Instrukcja do ćwiczenia Podstawy informatyki Elektrotechnika I rok Język C++ Operacje na danych - wskaźniki Instrukcja do ćwiczenia Katedra Energoelektroniki i Automatyki Systemów Przetwarzania Energii AGH Kraków 2017 Tematyka

Bardziej szczegółowo

1 Podstawy c++ w pigułce.

1 Podstawy c++ w pigułce. 1 Podstawy c++ w pigułce. 1.1 Struktura dokumentu. Kod programu c++ jest zwykłym tekstem napisanym w dowolnym edytorze. Plikowi takiemu nadaje się zwykle rozszerzenie.cpp i kompiluje za pomocą kompilatora,

Bardziej szczegółowo

typ y y p y z łoż o on o e n - tab a lice c e w iel e owym m ar a o r we, e stru r kt k ury

typ y y p y z łoż o on o e n - tab a lice c e w iel e owym m ar a o r we, e stru r kt k ury typy złożone- tablice wielowymiarowe, struktury Wykład 6 Deklarowanie wskaźników nazwa_typu * nazwa_wskaznika; WSKAŹNIKI: PRZYPOMNIENIE Przypisywanie wskaźnikom wartości double * pn = &zmienna_typu_double;

Bardziej szczegółowo

Podstawy programowania w języku C++

Podstawy programowania w języku C++ Podstawy programowania w języku C++ Część jedenasta Przetwarzanie plików amorficznych Konwencja języka C Autor Roman Simiński Kontakt roman.siminski@us.edu.pl www.us.edu.pl/~siminski Niniejsze opracowanie

Bardziej szczegółowo

Podstawy programowania w języku C++

Podstawy programowania w języku C++ Podstawy programowania w języku C++ Część ósma Zmienne wskaźnikowe koncepcja, podstawowe zastosowania Wersja skrócona, tylko C++ Autor Roman Simiński Kontakt roman.siminski@us.edu.pl www.us.edu.pl/~siminski

Bardziej szczegółowo

Struktury czyli rekordy w C/C++

Struktury czyli rekordy w C/C++ Struktury czyli rekordy w C/C++ Wprowadzenie do programowania w języku C struktury. pola bitowe, unie Struktury (rekordy) są złożonymi zmiennymi, składającymi się z elementów różnych typów zwanych polami,

Bardziej szczegółowo

część 8 wskaźniki - podstawy Jarosław Gramacki Instytut Informatyki i Elektroniki Podstawowe pojęcia

część 8 wskaźniki - podstawy Jarosław Gramacki Instytut Informatyki i Elektroniki Podstawowe pojęcia Język ANSI C część 8 wskaźniki - podstawy Jarosław Gramacki Instytut Informatyki i Elektroniki Podstawowe pojęcia najbardziej podstawowe operacje na wskaźnikach int x = 1, y = 2, Tab[10]; int *ip; // czy

Bardziej szczegółowo

Tablice. Monika Wrzosek (IM UG) Podstawy Programowania 96 / 119

Tablice. Monika Wrzosek (IM UG) Podstawy Programowania 96 / 119 Tablice Tablica to struktura danych, która może przechowywać wiele wartości tego samego typu. Na przykład tablica może zawierać: 10 wartości typu int opisujących liczbę studentów przyjętych na kierunek

Bardziej szczegółowo

Tablice mgr Tomasz Xięski, Instytut Informatyki, Uniwersytet Śląski Katowice, 2011

Tablice mgr Tomasz Xięski, Instytut Informatyki, Uniwersytet Śląski Katowice, 2011 Tablice mgr Tomasz Xięski, Instytut Informatyki, Uniwersytet Śląski Katowice, 2011 Załóżmy, że uprawiamy jogging i chcemy monitorować swoje postępy. W tym celu napiszemy program, który zlicza, ile czasu

Bardziej szczegółowo

wykład II uzupełnienie notatek: dr Jerzy Białkowski Programowanie C/C++ Język C - funkcje, tablice i wskaźniki wykład II dr Jarosław Mederski Spis

wykład II uzupełnienie notatek: dr Jerzy Białkowski Programowanie C/C++ Język C - funkcje, tablice i wskaźniki wykład II dr Jarosław Mederski Spis i cz. 2 Programowanie uzupełnienie notatek: dr Jerzy Białkowski 1 i cz. 2 2 i cz. 2 3 Funkcje i cz. 2 typ nazwa ( lista-parametrów ) { deklaracje instrukcje } i cz. 2 typ nazwa ( lista-parametrów ) { deklaracje

Bardziej szczegółowo

PODSTAWY INFORMATYKI 1 PRACOWNIA NR 6

PODSTAWY INFORMATYKI 1 PRACOWNIA NR 6 PODSTAWY INFORMATYKI 1 PRACOWNIA NR 6 TEMAT: Programowanie w języku C/C++: instrukcje iteracyjne for, while, do while Ogólna postać instrukcji for for (wyr1; wyr2; wyr3) Instrukcja for twory pętlę działającą

Bardziej szczegółowo

Wykład II Tablice (wstęp) Przykłady algorytmów Wstęp do języka C/C++

Wykład II Tablice (wstęp) Przykłady algorytmów Wstęp do języka C/C++ Podstawy programowania Wykład II Tablice (wstęp) Przykłady algorytmów Wstęp do języka C/C++ 1 dr Artur Bartoszewski - Podstawy programowania, sem. 1- WYKŁAD Część I Wstęp do struktur danych: Tablice 2

Bardziej szczegółowo

Wykład 1. Program przedmiotu. Programowanie (język C++) Literatura. Program przedmiotu c.d.:

Wykład 1. Program przedmiotu. Programowanie (język C++) Literatura. Program przedmiotu c.d.: Program przedmiotu Programowanie (język C++) Wykład 1. Język C a C++. Definiowanie prostych klas. Typy referencyjne. Domyślne wartości argumentów. PrzeciąŜanie funkcji. Konstruktory, destruktory. Definiowanie

Bardziej szczegółowo

Podstawy programowania. Wykład: 8. Wskaźniki. dr Artur Bartoszewski -Podstawy programowania, sem 1 - WYKŁAD

Podstawy programowania. Wykład: 8. Wskaźniki. dr Artur Bartoszewski -Podstawy programowania, sem 1 - WYKŁAD Podstawy programowania Wykład: 8 Wskaźniki 1 dr Artur Bartoszewski -Podstawy programowania, sem 1 - WYKŁAD Podstawy programowania w C++ Wskaźniki 2 Podstawy Pojęcie wskaźnika Wskaźnik na zmienną danego

Bardziej szczegółowo

Techniki Programowania wskaźniki

Techniki Programowania wskaźniki Techniki Programowania wskaźniki Łukasz Madej Katedra Informatyki Stosowanej i Modelowania Wykłady opracowane we współpracy z Danutą Szeligą, Łukaszem Sztangretem Wskaźniki Dla typu T zapis T* oznacza

Bardziej szczegółowo

2 Przygotował: mgr inż. Maciej Lasota

2 Przygotował: mgr inż. Maciej Lasota Laboratorium nr 2 1/7 Język C Instrukcja laboratoryjna Temat: Wprowadzenie do języka C 2 Przygotował: mgr inż. Maciej Lasota 1) Wprowadzenie do języka C. Język C jest językiem programowania ogólnego zastosowania

Bardziej szczegółowo

Podstawy programowania. Wykład 6 Złożone typy danych: struktury, unie. Krzysztof Banaś Podstawy programowania 1

Podstawy programowania. Wykład 6 Złożone typy danych: struktury, unie. Krzysztof Banaś Podstawy programowania 1 Podstawy programowania. Wykład 6 Złożone typy danych: struktury, unie Krzysztof Banaś Podstawy programowania 1 są sposobem na przechowywanie w ramach pojedynczej zmiennej zestawu zmiennych różnych typów,

Bardziej szczegółowo

Dla każdej operacji łącznie tworzenia danych i zapisu ich do pliku przeprowadzić pomiar czasu wykonania polecenia. Wyniki przedstawić w tabelce.

Dla każdej operacji łącznie tworzenia danych i zapisu ich do pliku przeprowadzić pomiar czasu wykonania polecenia. Wyniki przedstawić w tabelce. Przygotować program tworzący tablicę dwuwymiarową zawierającą zestawy 10 2, 10 4, 10 6 liczb losowych zmiennoprzecinkowych. Korzystając z funkcji bibliotecznych uporządkować zawartość każdego (a) wiersza

Bardziej szczegółowo

Spis treści PLIKI BINARNE W JĘZYKU C. Informatyka 2. Instrukcja do pracowni specjalistycznej z przedmiotu. Numer ćwiczenia INF23

Spis treści PLIKI BINARNE W JĘZYKU C. Informatyka 2. Instrukcja do pracowni specjalistycznej z przedmiotu. Numer ćwiczenia INF23 Politechnika Białostocka Wydział Elektryczny Katedra Elektrotechniki Teoretycznej i Metrologii Instrukcja do pracowni specjalistycznej z przedmiotu Informatyka 2 Kod przedmiotu: ES1C300 016 (studia stacjonarne)

Bardziej szczegółowo

Spis treści JĘZYK C - PLIKI BINARNE. Informatyka 2. Instrukcja do pracowni specjalistycznej z przedmiotu. Numer ćwiczenia INF30

Spis treści JĘZYK C - PLIKI BINARNE. Informatyka 2. Instrukcja do pracowni specjalistycznej z przedmiotu. Numer ćwiczenia INF30 Politechnika Białostocka Wydział Elektryczny Katedra Elektrotechniki Teoretycznej i Metrologii Instrukcja do pracowni specjalistycznej z przedmiotu Informatyka 2 Kod przedmiotu: ES1D300 017 (studia stacjonarne)

Bardziej szczegółowo

Wymiar musi być wyrażeniem stałym typu całkowitego, tzn. takim, które może obliczyć kompilator. Przykłady:

Wymiar musi być wyrażeniem stałym typu całkowitego, tzn. takim, które może obliczyć kompilator. Przykłady: 5 Tablice Tablica jest zestawem obiektów (zmiennych) tego samego typu, do których można się odwołać za pomocą wspólnej nazwy. Obiekty składowe tablicy noszą nazwę elementów tablicy. Dostęp do nich jest

Bardziej szczegółowo

Wykład 5: Klasy cz. 3

Wykład 5: Klasy cz. 3 Programowanie obiektowe Wykład 5: cz. 3 1 dr Artur Bartoszewski - Programowanie obiektowe, sem. 1I- WYKŁAD - podstawy Konstruktor i destruktor (część I) 2 Konstruktor i destruktor KONSTRUKTOR Dla przykładu

Bardziej szczegółowo

Spis treści JĘZYK C - INSTRUKCJA WARUNKOWA IF, OPERATORY RELACYJNE I LOGICZNE, WYRAŻENIA LOGICZNE, ZAGNIEŻDŻANIE IF-ELSE.

Spis treści JĘZYK C - INSTRUKCJA WARUNKOWA IF, OPERATORY RELACYJNE I LOGICZNE, WYRAŻENIA LOGICZNE, ZAGNIEŻDŻANIE IF-ELSE. Politechnika Białostocka Wydział Elektryczny Katedra Elektrotechniki Teoretycznej i Metrologii Instrukcja do pracowni specjalistycznej z przedmiotu Informatyka 1 Kod przedmiotu: ES1D200 009 (studia stacjonarne)

Bardziej szczegółowo

Struktury Struktura polami struct struct struct struct

Struktury Struktura polami struct struct struct struct Struktury Struktura jest zbiorem zmiennych występujących pod wspólna nazwą. Zmienne wchodzące w skład struktury nazywane są polami lub elementami, a czasem członkami struktury. Struktury używamy, jeśli

Bardziej szczegółowo

Podstawy Programowania

Podstawy Programowania Podstawy Programowania Monika Wrzosek Instytut Matematyki Uniwersytet Gdański Matematyka 2017/18 Monika Wrzosek (IM UG) Podstawy Programowania 1 / 119 Sprawy organizacyjne E-mail: mwrzosek@mat.ug.edu.pl

Bardziej szczegółowo