dr inż. Jarosław Forenc

Podobne dokumenty
Informatyka 1. Wykład nr 8 ( ) Politechnika Białostocka. - Wydział Elektryczny. dr inŝ. Jarosław Forenc

dr inż. Jarosław Forenc

Informatyka 1. Wykład nr 8 ( ) Plan wykładu nr 8. Politechnika Białostocka. - Wydział Elektryczny. Asembler - przykład programu.

dr inż. Jarosław Forenc

Konsultacje: dr inż. Jarosław Forenc

dr inż. Jarosław Forenc

dr inż. Jarosław Forenc

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

Informatyka 1. Wykład nr 8 ( ) Plan wykładu nr 8. Politechnika Białostocka. - Wydział Elektryczny. language) Asembler - przykład programu

Algorytmy komputerowe. dr inż. Jarosław Forenc

Wykład V. Rzut okiem na języki programowania. Studia Podyplomowe INFORMATYKA Podstawy Informatyki

INFORMATYKA, TECHNOLOGIA INFORMACYJNA ORAZ INFORMATYKA W LOGISTYCE

dr inż. Jarosław Forenc

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

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

Algorytmy komputerowe. dr inŝ. Jarosław Forenc

Programowanie. programowania. Klasa 3 Lekcja 9 PASCAL & C++

Podstawy programowania. Wprowadzenie

Podstawy programowania wykład

Programowanie komputerów

Język ludzki kod maszynowy

Technologie informacyjne - wykład 12 -

Programowanie Strukturalne i Obiektowe Słownik podstawowych pojęć 1 z 5 Opracował Jan T. Biernat

Podstawy programowania. Wykład Funkcje. Krzysztof Banaś Podstawy programowania 1

Algorytm. a programowanie -

Metodyki i techniki programowania

Algorytmy od problemu do wyniku

Metodyki i techniki programowania

Podstawy Programowania

Programowanie obiektowo zorientowane. Mirosław Głowacki Wykład w języku C++

Język programowania PASCAL

Wykład 8: klasy cz. 4

Paradygmaty programowania

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

Praktyka Programowania

Podstawy programowania. Wykład: 13. Rekurencja. dr Artur Bartoszewski -Podstawy programowania, sem 1 - WYKŁAD

Matematyczne Podstawy Informatyki

Wykład 4. Algorytmy i programy. Algorytmy + struktury danych = programy. Niklaus Wirth. Algorytm = logika + sterowanie.

Rok akademicki: 2012/2013 Kod: EAR s Punkty ECTS: 3. Poziom studiów: Studia I stopnia Forma i tryb studiów: -

Języki i paradygmaty programowania Wykład 2. Dariusz Wardowski. dr Dariusz Wardowski, Katedra Analizy Nieliniowej, WMiI UŁ 1/18

Języki i paradygmaty programowania

MATERIAŁY DO ZAJĘĆ I. Podstawowe pojęcia. Algorytm. Spis treści Przepis

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

PRZEWODNIK PO PRZEDMIOCIE

KARTA KURSU. Wstęp do programowania

E-1EZ1-03-s2. Elektrotechnika I stopień (I stopień / II stopień) Ogólnoakademicki (ogólno akademicki / praktyczny)

Dariusz Brzeziński. Politechnika Poznańska, Instytut Informatyki

Początki Javy. dr Anna Łazińska, WMiI UŁ Podstawy języka Java 1 / 8

Java EE produkcja oprogramowania

Zaliczenie przedmiotu:

Wstęp do Informatyki. Program, proces tworzenia programu Środowisko programistyczne Języki programowania

1 Wprowadzenie do algorytmiki

I. KARTA PRZEDMIOTU CEL PRZEDMIOTU WYMAGANIA WSTĘPNE W ZAKRESIE WIEDZY, UMIEJĘTNOŚCI I INNYCH KOMPETENCJI EFEKTY KSZTAŁCENIA

Wstęp do Informatyki i Programowania

1. Nagłówek funkcji: int funkcja(void); wskazuje na to, że ta funkcja. 2. Schemat blokowy przedstawia algorytm obliczania

Wstęp do programowania obiektowego. Wykład 1 Algorytmy i paradygmaty Podstawowe pojęcia PO

Języki programowania II - opis przedmiotu

Programowanie obiektowe Wykład 1. Dariusz Wardowski. dr Dariusz Wardowski, Katedra Analizy Nieliniowej, WMiI UŁ 1/20

Informatyka I. Klasy i obiekty. Podstawy programowania obiektowego. dr inż. Andrzej Czerepicki. Politechnika Warszawska Wydział Transportu 2018

Elektrotechnika I stopień (I stopień / II stopień) Ogólno akademicki (ogólno akademicki / praktyczny) Kierunkowy (podstawowy / kierunkowy / inny HES)

Opisy efektów kształcenia dla modułu

PRZEWODNIK PO PRZEDMIOCIE

PRYWATNA WYŻSZA SZKOŁA BUSINESSU, ADMINISTRACJI I TECHNIK KOMPUTEROWYCH S Y L A B U S

Język C++ wykład VIII

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

Wykład 5: Klasy cz. 3

Programowanie, algorytmy i struktury danych

Programowanie w języku C++ Podstawowe paradygmaty programowania

Historia modeli programowania

Opis efektów kształcenia dla modułu zajęć

Elektrotechnika I stopień (I stopień / II stopień) Ogólnoakademicki (ogólno akademicki / praktyczny) Niestacjonarne (stacjonarne / niestacjonarne)

Java jako język programowania

Algorytmy. Programowanie Proceduralne 1

WYKŁAD. Jednostka prowadząca: Wydział Techniczny. Kierunek studiów: Elektronika i telekomunikacja. Nazwa przedmiotu: Język programowania C++

Algorytmika i pseudoprogramowanie

Wstęp do programowania INP001213Wcl rok akademicki 2017/18 semestr zimowy. Wykład 13. Karol Tarnowski A-1 p.

Programowanie obiektowe W1 Wprowadzenie. Dr hab. inż. Lucyna Leniowska, prof. UR Zakład Mechatroniki, Automatyki i Optoelektroniki

KARTA PRZEDMIOTU. 1. Informacje ogólne. 2. Ogólna charakterystyka przedmiotu. Algorytmy i struktury danych, C3

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

Elżbieta Kula - wprowadzenie do Turbo Pascala i algorytmiki

Programowanie I. Wprowadzenie. Proces programowania

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

Instrukcja do pracowni specjalistycznej z przedmiotu. Obiektowe programowanie aplikacji

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

Język programowania C C Programming Language. ogólnoakademicki

Technologie informacyjne Wykład VII-IX

KONSTRUKCJA KOMPILATORÓW

Czym jest Java? Rozumiana jako środowisko do uruchamiania programów Platforma software owa

Wykład I. Programowanie II - semestr II Kierunek Informatyka. dr inż. Janusz Słupik. Wydział Matematyki Stosowanej Politechniki Śląskiej

Programowanie obiektowe. Literatura: Autor: dr inŝ. Zofia Kruczkiewicz

JAVA. Java jest wszechstronnym językiem programowania, zorientowanym. apletów oraz samodzielnych aplikacji.

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

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

Podstawy i języki programowania

Wykład Ćwiczenia Laboratorium Projekt Seminarium

Języki programowania zasady ich tworzenia

Programowanie i projektowanie obiektowe

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

Podstawy języka Java. przygotował:

Szablony funkcji i klas (templates)

Transkrypt:

Informatyka 2 Politechnika Białostocka - Wydział Elektryczny Elektrotechnika, semestr III, studia stacjonarne I stopnia Rok akademicki 2012/2013 Wykład nr 1 (04.10.2012)

Rok akademicki 2012/2013, Wykład nr 1 2/73 Dane podstawowe Politechnika Białostocka, Wydział Elektryczny, Katedra Elektrotechniki Teoretycznej i Metrologii ul. Wiejska 45D, 15-351 Białystok WE-204 e-mail: j.forenc@pb.edu.pl tel. (0-85) 746-93-97 http://we.pb.edu.pl/~jforenc Dydaktyka - slajdy prezentowane na wykładzie Konsultacje: Środa, godz. 17:40-19:10, WE-204 Piątek, godz. 11:30-13:00, WE-204

Rok akademicki 2012/2013, Wykład nr 1 3/73 Przedmioty Informatyka 1 i Informatyka 2 Informatyka 1 semestr II wykład: 15 godz. (J. Forenc) pracownia specjalistyczna: 30 godz. (A. Choroszucho, J. Forenc) ECTS: 4 pkt. kod przedmiotu: ES1A200 009 Informatyka 2 semestr III wykład: 15 godz. (J. Forenc) pracownia specjalistyczna: 30 godz. (J. Forenc) ECTS: 4 pkt. kod przedmiotu: ES1A300 016

Rok akademicki 2012/2013, Wykład nr 1 4/73 Program wykładu (1/2) 1. Wskaźniki, operacje na wskaźnikach, wskaźniki i tablice. Dynamiczny przydział pamięci. Dynamiczne struktury danych: stos, kolejka, lista. Przykłady zastosowań. 2. Programowanie obiektowe w języku C++. Operacje wejścia-wyjścia. Klasy i obiekty. Składniki klasy: dane i funkcje. Prawa dostępu do składników klasy. Definiowanie funkcji składowych klasy. Konstruktory i destruktory. Przeładowanie operatorów. Dziedziczenie. Funkcje wirtualne. 3. Operacje na wektorach i macierzach. Mnożenie macierzy, normy wektorów i macierzy, wyznacznik macierzy.

Rok akademicki 2012/2013, Wykład nr 1 5/73 Program wykładu (2/2) 4. Sortowanie. Klasyfikacje algorytmów sortowania. Algorytmy sortowania: przez proste wstawianie, przez proste wybieranie, bąbelkowe, szybkie (Quick-Sort). 5. System operacyjny. Funkcje i zadania systemu operacyjnego. Zarządzanie procesami, pamięcią (stronicowanie, segmentacja, pamięć wirtualna) i dyskami. Struktura i właściwości systemów Windows i Linux. 6. Sieci komputerowe. Technologie, protokoły, urządzenia. Zasada działania sieci Internet. 7. Relacyjne bazy danych. Podstawowe pojęcia, organizacja i zasady wykorzystania.

Rok akademicki 2012/2013, Wykład nr 1 6/73 Literatura (1/4) Programowanie w C/C++: 1. B.W. Kernighan, D.M. Ritchie: Język ANSI C. Programowanie. Wydanie II. Helion, Gliwice, 2010. 2. J. Grębosz: Symfonia C++ standard: programowanie w języku C++ orientowane obiektowo. Tom 1 i 2. Wydawnictwo Edition 2000, Kraków, 2008. 3. B. Stroustrup: Programowanie. Teoria i praktyka z wykorzystaniem C++. Helion, Gliwice, 2010. 4. B. Eckel: Thinking in C++. Edycja polska. Helion, Gliwice, 2002. 5. S. Prata: Język C++. Szkoła programowania. Wydanie V. Helion, Gliwice, 2006.

Rok akademicki 2012/2013, Wykład nr 1 7/73 Literatura (2/4) Metody numeryczne: 1. D. Kincaid, W. Cheney: Analiza numeryczna. WNT, Warszawa, 2006. Algorytmy i struktury danych: 1. T.H. Cormen i in.: Wprowadzenie do algorytmów. PWN, Warszawa, 2012. 2. P. Wróblewski: Algorytmy, struktury danych i techniki programowania. Wydanie IV. Helion, Gliwice, 2009. 3. N. Wirth: Algorytmy + struktury danych = programy. WNT, Warszawa, 2004.

Rok akademicki 2012/2013, Wykład nr 1 8/73 Literatura (3/4) Systemy operacyjne: 1. A.S. Tanenbaum: Systemy operacyjne. Wydanie III. Helion, Gliwice, 2010. 2. A. Silberschatz i in.: Podstawy systemów operacyjnych. WNT, Warszawa, 2006. 3. W. Stallings: Systemy operacyjne. Struktura i zasady budowy. Mikom, Warszawa, 2006. Sieci komputerowe: 1. D.E. Comer: Sieci komputerowe i intersieci. Wydanie V. Helion, Gliwice, 2012.

Rok akademicki 2012/2013, Wykład nr 1 9/73 Literatura (4/4) Bazy danych: 1. H. Garcia-Molina i in.: Systemy baz danych. Pełny wykład. WNT, Warszawa, 2006. 2. M. Whitehorn, B. Marklyn: Relacyjne bazy danych. Helion. Gliwice, 2003.

Rok akademicki 2012/2013, Wykład nr 1 10/73 Zaliczenie wykładu Sprawdzian pisemny na koniec semestru 4 pytania, za każde pytanie można otrzymać od 0 do 10 pkt. Suma punktów decyduje o ocenie końcowej: 37 pkt. - 40 pkt. - ocena: 5 33 pkt. - 36 pkt. - ocena: 4,5 29 pkt. - 32 pkt. - ocena: 4 25 pkt. - 28 pkt. - ocena: 3,5 21 pkt. - 24 pkt. - ocena: 3 0 pkt. - 20 pkt. - ocena: 2 Termin zaliczenia: 17.01.2013 (przedostatni wykład) Zaliczenie poprawkowe: 31.01.2013 (ostatni wykład) Przykładowe pytania zaliczeniowe - koniec grudnia 2012 roku

Rok akademicki 2012/2013, Wykład nr 1 11/73 Terminy zajęć Wykład nr 1-04.10.2012 Wykład nr 2-18.10.2012 Wykład nr 3-08.11.2012 Wykład nr 4-22.11.2012 Wykład nr 5-06.12.2012 Wykład nr 6-20.12.2012 Wykład nr 7-17.01.2013 (zaliczenie) Wykład nr 8-31.01.2013 (zaliczenie poprawkowe)

Rok akademicki 2012/2013, Wykład nr 1 12/73 Plan wykładu nr 1 (Informatyka 1) Algorytmy definicje sposoby opisu paradygmaty tworzenia programów komputerowych rekurencja złożoność obliczeniowa Języki programowania kompilowane i interpretowane języki programowania generacje języków programowania przykłady języków: asembler, Fortran, BASIC, Pascal, Java, C#

Rok akademicki 2012/2013, Wykład nr 1 13/73 Algorytm - definicje Definicja 1 Skończony, uporządkowany ciąg jasno zdefiniowanych czynności, koniecznych do wykonania pewnego zadania Definicja 2 Metoda rozwiązania zadania Definicja 3 Ściśle określona procedura obliczeniowa, która dla właściwych danych wejściowych zwraca żądane dane wyjściowe zwane wynikiem działania algorytmu

Rok akademicki 2012/2013, Wykład nr 1 14/73 Sposoby opisu algorytmów 1. Opis słowny algorytmu (w języku naturalnym) 2. Opis w punktach (lista kroków) 3. Opis w postaci schematu blokowego 4. Z zastosowaniem pseudokodu, czyli niezbyt formalnej odmiany języka programowania 5. W wybranym języku programowania

Informatyka 1, studia niestacjonarne I stopnia Rok akademicki 2011/2012, Wykład nr 9 15/63 Paradygmaty tworzenia programów komputerowych Strategia dziel i zwyciężaj Programowanie dynamiczne Algorytmy zachłanne Programowanie liniowe Algorytmy siłowe (brute force) Algorytmy probabilistyczne

Informatyka 1, studia niestacjonarne I stopnia Rok akademicki 2011/2012, Wykład nr 9 16/63 Strategia dziel i zwyciężaj Strategia dziel i zwyciężaj (ang. divide and conquer) - bardzo efektywna strategii konstruowania algorytmów komputerowych Rozwiązywany problem dzielony jest na dwa lub więcej mniejszych problemów tego samego typu (lub podobnego) tak długo, aż stanie się on wystarczająco prosty do bezpośredniego rozwiązania Rozwiązania otrzymane dla mniejszych podproblemów są scalane w celu uzyskania rozwiązania całego zadania (jeśli jest to konieczne) Przykłady zastosowań: sortowanie szybkie (quicksort) wyszukiwanie binarne - sprawdzenie czy element znajduje się w uporządkowanej tablicy, jeśli tak, to zwracany jest jego indeks poszukiwanie miejsc zerowych funkcji nieliniowej metodą bisekcji mnożenie macierzy metodą Strassena

Informatyka 1, studia niestacjonarne I stopnia Rok akademicki 2011/2012, Wykład nr 9 17/63 Programowanie dynamiczne Konstrukcja programu sformułowana jest w trzech etapach: Koncepcja: stworzenie rekurencyjnego modelu rozwiązania problemu (wraz z jednoznacznym określeniem przypadków elementarnych) stworzenie tablicy, zawierającej rozwiązania przypadków elementarnych i obliczonych na ich podstawie podproblemów Inicjacja: wpisanie do tablicy wartości dla przypadków elementarnych Progresja: obliczenie i wpisanie do tablicy rozwiązania problemu wyższego rzędu (na podstawie formuły rekurencyjnej i już wpisanych wartości) postępowanie w ten sam sposób do osiągnięcia pożądanej wartości

Informatyka 1, studia niestacjonarne I stopnia Rok akademicki 2011/2012, Wykład nr 9 18/63 Programowanie dynamiczne - przykład Koncepcja: (F 10 w ciągu Fibonacciego) model rekurencyjny, przypadki elementarne, tablica z rozwiązaniem F 0 = 0, F1 = 1, Fn = Fn 1 + Fn 2 n 0 1 2 3 4 5 6 7 8 9 10 F n Inicjacja: wpisanie do tablicy wartości dla przypadków elementarnych Progresja: n 0 1 2 3 4 5 6 7 8 9 10 F n 0 1 obliczenie rozwiązań problemów wyższego rzędu aż do osiągnięcia pożądanej wartości i wpisanie ich do tablicy n 0 1 2 3 4 5 6 7 8 9 10 F n 0 1 1 2 3 5 8 13 21 34 55

Informatyka 1, studia niestacjonarne I stopnia Rok akademicki 2011/2012, Wykład nr 9 19/63 Algorytmy zachłanne Algorytm zachłanny (greedy) - w celu rozwiązania pewnego zadania w każdym kroku dokonuje się zachłannego, tj. najlepiej rokującego w danym momencie wyboru rozwiązania częściowego Algorytm podejmuje decyzję lokalnie optymalną, dokonując wyboru wydającego się w danej chwili najlepszym co ma w założeniu prowadzić do znalezienia globalnego optymalnego rozwiązania Stosowane przede wszystkim w optymalizacji

Informatyka 1, studia niestacjonarne I stopnia Rok akademicki 2011/2012, Wykład nr 9 20/63 Algorytmy siłowe Algorytm siłowy (brute force) - opiera się na sukcesywnym sprawdzaniu wszystkich możliwych kombinacji w poszukiwaniu rozwiązania problemu Zazwyczaj nieoptymalny, ale najprostszy w implementacji W programowaniu termin ten odnosi się do dowolnego algorytmu, który rozwiązuje problem przez weryfikację i ocenę wszystkich wariantów postępowania Atak brute force - w bezpieczeństwie komputerowym jest to próba złamania zabezpieczeń przez sukcesywne sprawdzanie wszystkich możliwości

Informatyka 1, studia niestacjonarne I stopnia Rok akademicki 2011/2012, Wykład nr 9 21/63 Algorytmy probabilistyczne Algorytmy można podzielić na deterministyczne i probabilistyczne Dane wejściowe Dane wejściowe Algorytm deterministyczny Algorytm probabilistyczny Generator liczb losowych Dane wyjściowe Dane wyjściowe Działanie algorytmu deterministycznego jest całkowicie zależne od warunków początkowych (wejście), tzn. dla takich samych danych wejściowych algorytm zawsze zwraca taki sam wynik Algorytm probabilistyczny albo randomizowany (randomized algorithm) do swojego działania używa losowości (generatora liczb pseudolosowych)

Informatyka 1, studia niestacjonarne I stopnia Rok akademicki 2011/2012, Wykład nr 9 22/63 Metoda Monte Carlo - obliczanie całki oznaczonej Obliczanie przybliżonej wartości całki oznaczonej metodą Monte Carlo: Dla funkcji f(x), której całkę chcemy obliczyć w przedziale [x p,x k ] wyznaczamy prostokąt obejmujący pole pod wykresem tej funkcji o wysokości h i długości podstawy (x k -x p ) x k I = f ( x) dx x p Losujemy n punktów i zliczamy te punkty n w, które wpadają w pole pod wykresem funkcji Wartość całki obliczana jest na podstawie wzoru przybliżonego: I x k = x p f nw ( x) dx h( xk x p ) n

Informatyka 1, studia niestacjonarne I stopnia Rok akademicki 2011/2012, Wykład nr 9 23/63 Metoda Monte Carlo - obliczanie liczby π Obliczamy pole koła wpisanego w kwadrat o boku równym 2r, gdzie r - promień koła Pola koła i kwadratu opisują wzory: P koło = π r 2 P kwadrat = 2 2 ( 2 r ) = 4 r Po porównaniu powyższych wzorów otrzymamy: Pkoło 2 Pkwadrat Pkoło r =, r = = π 4 π 2 kwadrat P 4 czyli: π = 4 P P koło kwadrat

Informatyka 1, studia niestacjonarne I stopnia Rok akademicki 2011/2012, Wykład nr 9 24/63 Metoda Monte Carlo - obliczanie liczby π Wyznaczamy wewnątrz kwadratu bardzo dużo losowych punktów Zliczamy punkty, które wpadają do wnętrza koła Przybliżona wartość liczby π: π P P koło = 4 4 kwadrat n n koło kwadrat gdzie: n koło - liczba punktów w kole n kwadrat - liczba wszystkich punktów Pierwsze zastosowanie: Marquis Pierre-Simon de Laplace (1886)

Informatyka 1, studia niestacjonarne I stopnia Rok akademicki 2011/2012, Wykład nr 9 25/63 Metoda Monte Carlo - obliczanie liczby π Średnie wyniki przy 10 000 powtórzeń losowania: n kwadrat n koło wartość Średnia liczby π Średni błąd bezwzględny Średni błąd względny 10 7,8459 3,138298 0,417763 13,2984% 100 78,4887 3,139505 0,141593 4,1621% 1 000 785,388 3,141543 0,040952 1,3036% 10 000 7853,08 3,141234 0,013222 0,4209% 100 000 78532,6 3,141299 0,004156 0,1323% Dokładność wyniku zależy od: liczby sprawdzeń (n kwadrat ) jakości użytego generatora liczb pseudolosowych

Rok akademicki 2012/2013, Wykład nr 1 26/73 Rekurencja Rekurencja lub rekursja - jest to odwoływanie się funkcji lub definicji do samej siebie Rozwiązanie danego problemu wyraża się za pomocą rozwiązań tego samego problemu, ale dla danych o mniejszych rozmiarach W matematyce mechanizm rekurencji stosowany jest do definiowania lub opisywania algorytmów Przykład - silnia: 1 n! = n( n 1)! dla dla n = 0 n 1 int silnia(int n) { return n==0? 1 : n*silnia(n-1); }

Rok akademicki 2012/2013, Wykład nr 1 27/73 Rekurencja - przykłady Przykład - ciąg Fibonacciego: 0 dla n = 0 F n = 1 dla n = 1 F F dla > n 1 + n 2 n 1 int F(int n) { if (n==0) return 0; else if (n==1) return 1; else return F(n-1) + F(n-2); }

Rok akademicki 2012/2013, Wykład nr 1 28/73 Rekurencja - przykłady Przykład - algorytm Euklidesa (największy wspólny dzielnik): NWD( a, b) = a NWD( b, a mod b) dla dla b b = 0 1 int NWD(int a, int b) { if (b==0) return a; else return NWD(b,a % b); }

Rok akademicki 2012/2013, Wykład nr 1 29/73 Złożoność obliczeniowa W celu rozwiązania danego problemu obliczeniowego szukamy algorytmu najbardziej efektywnego czyli: najszybszego o możliwie małym zapotrzebowaniu na pamięć Do oceny efektywności programu służy złożoność obliczeniowa (koszt algorytmu) Złożoność obliczeniowa algorytmu: jest ilością zasobów potrzebnych do jego działania (czas, pamięć) jest funkcją rozmiaru danych, na których pracuje algorytm

Rok akademicki 2012/2013, Wykład nr 1 30/73 Złożoność obliczeniowa Złożoność czasowa: Jej miarą jest liczba podstawowych operacji (dominujących) Podstawowe operacje - porównanie, podstawienie, operacja arytmetyczna Złożoność pamięciowa: Jest miarą wykorzystania pamięci (liczba komórek pamięci) Złożoność pesymistyczna: Odpowiada danym najbardziej niesprzyjającym dla algorytmu Złożoność średnia: Złożoność uśredniona po wszystkich możliwych zestawach danych, występująca dla typowych danych wejściowych

Rok akademicki 2012/2013, Wykład nr 1 31/73 Notacja O ( duże O ) Wyraża złożoność matematyczną algorytmu Po literze O występuje wyrażenie w nawiasach zawierające literę n, która oznacza liczbę elementów, na której działa algorytm Do wyznaczenia złożoności bierze się pod uwagę liczbę wykonywanych w algorytmie podstawowych operacji Przykład: O(n) - złożoność algorytmu jest prostą funkcją liczby elementów (jeśli sortowanie 10.000 elementów zajmuje 5 s, to sortowanie 20.000 elementów zajmie 10 s) O(n 2 )- czas konieczny do wykonania algorytmu rośnie wraz z kwadratem liczby elementów (przy podwojeniu liczby elementów ich obsługa będzie trwała cztery razy dłużej)

Rok akademicki 2012/2013, Wykład nr 1 32/73 Notacja O ( duże O ) Porównanie najczęściej występujących złożoności: n O(log n) O(n) O(n logn) O(n 2 ) O(2 n ) 10 3 10 33 100 1024 100 7 100 664 10 000 1,27 10 30 1 000 10 1 000 9 966 1 000 000 1,07 10 301 10 000 13 10 000 132 877 100000000 1,99 10 3010 O(log n) - złożoność logarytmiczna O(n) - złożoność liniowa O(n log n) - złożoność liniowo-logarytmiczna (quasi-liniowa) O(n 2 ) - złożoność kwadratowa O(2 n ) - złożoność wykładnicza

Rok akademicki 2012/2013, Wykład nr 1 33/73 Język programowania Język programowania - usystematyzowany sposób przekazywania komputerowi poleceń do wykonania Pozwala na dokładny zapis algorytmów oraz innych zadań jakie komputer ma wykonać Dane + algorytm Symbole Język programowania Słowa kluczowe Składnia Semantyka Program

Rok akademicki 2012/2013, Wykład nr 1 34/73 Język programowania Składnia języka określa: sposób opisywania struktur sterujących sposób opisywania struktur danych sposób tworzenia poprawnych symboli do nazywania zmiennych i struktur danych sposób stosowania interpunkcji, tj. znaków typu spacje, średniki, kropki, nawiasy sposób budowy poprawnych wyrażeń Semantyka języka określa znaczenie poprawnych składniowo wyrażeń

Rok akademicki 2012/2013, Wykład nr 1 35/73 Język programowania Implementacja języka - konkretna realizacja języka dla maszyn określonego typu Program komputerowy - zbiór (ciąg) instrukcji opisujących zadanie, które ma wykonać komputer Kod źródłowy - postać programu wyrażona w języku programowania Przetwarzanie kodu źródłowego odbywa się na dwa sposoby kompilacja (kompilowane języki programowania) interpretacja (interpretowane języki programowania)

Rok akademicki 2012/2013, Wykład nr 1 36/73 Kompilowane języki programowania Kod źródłowy jest tłumaczony do postaci kodu maszynowego (sekwencji operacji gotowych do przetworzenia przez procesor) Kompilacja do kodu maszynowego zapewnia najwyższą wydajność Wygenerowany kod jest ściśle powiązany z platformą sprzętową Przykłady kompilowanych języków programowania: C C++ Pascal Fortran

Rok akademicki 2012/2013, Wykład nr 1 37/73 Interpretowane języki programowania Kod źródłowy jest na bieżąco tłumaczony i wykonywany przez dodatkowy program zwany interpreterem Zapewnia większą przenośność programów, które są często niezależne od platformy i systemu operacyjnego Programy w językach interpretowanych są mniej wydajne niż w językach kompilowanych Przykłady interpretowanych języków programowania: Java C# Perl Python Ruby

Rok akademicki 2012/2013, Wykład nr 1 38/73 Generacje języków programowania Generacje języków opisują zaawansowanie (rozbudowanie) struktury języka, co jest równocześnie związane z łatwością posługiwania się nimi im mniejsza liczba oznaczająca generację języka tym bardziej jest on zbliżony do sprzętu im większa generacja języka tym jest on bardziej intuicyjny i niezależny od sprzętu

Rok akademicki 2012/2013, Wykład nr 1 39/73 Języki programowania Istnieje około 2500 języków programowania http://www.oreilly.com/pub/a/oreilly/news/languageposter_0504.html (do 2004 roku)

Rok akademicki 2012/2013, Wykład nr 1 40/73 Języki programowania http://www.oreilly.com/pub/a/oreilly/news/languageposter_0504.html (do 2004 roku)

Rok akademicki 2012/2013, Wykład nr 1 41/73 TIOBE Programming Community Index (Sep 2012) 2) Position Sep 2012 Position Sep 2011 Programming Language Ratings Sep 2012 Delta Sep 2011 1 2 C 19.295% +1.29% 2 1 Java 16.267% -2.49% 3 6 Objective-C 9.770% +3.61% 4 3 C++ 9.147% +0.30% 5 4 C# 6.596% -0.22% 6 5 PHP 5.614% -0.98% 7 7 (Visual) Basic 5.528% +0.96% 8 8 Python 3.861% -0.14% 9 9 Perl 2.267% -0.20% 10 11 Ruby 1.724% +0.29% http://www.tiobe.com/index.php/content/paperinfo/tpci/index.html

Rok akademicki 2012/2013, Wykład nr 1 42/73 TIOBE Programming Community Index (Sep 2012) 2) Position Sep 2012 Position Sep 2011 Programming Language Ratings Sep 2012 Delta Sep 2011 11 10 Java Script 1.328% -0.14% 12 12 Delphi/Object Pascal 0.993% -0.32% 13 14 Lisp 0.969% -0.07% 14 15 Transcat-SQL 0.875% +0.02% 15 39 Visual Basic.NET 0.840% +0.53% 16 16 Pascal 0.830% -0.02% 17 13 Lua 0.723% -0.43% 18 18 Ada 0.700% +0.02% 19 17 PL/SQL 0.604% -0.12% 20 22 MATLAB 0.563% +0.02% http://www.tiobe.com/index.php/content/paperinfo/tpci/index.html

Rok akademicki 2012/2013, Wykład nr 1 43/73 TIOBE Programming Community Index (Sep 2012) 2)

Rok akademicki 2012/2013, Wykład nr 1 44/73 Asembler (assembly language) Język programowania niskiego poziomu Powstał na bazie języka maszynowego danego procesora poprzez zastąpienie kodów liczbowych instrukcji kodu maszynowego ich mnemonikami Program w asemblerze jest tłumaczony na kod maszynowy Zazwyczaj jedna instrukcja w asemblerze odpowiada jednemu rozkazowi procesora Składnia języka asemblera zależy od architektury procesora oraz używanego asemblera Tworzenie programu jest dość trudne, ale umożliwia programiście pełną kontrolę nad procesorem Programy napisane w asemblerze są bardzo wydajne

Rok akademicki 2012/2013, Wykład nr 1 45/73 Asembler - przykład programu.model SMALL.286.stack 100h.code start: jmp begin handler: pusha push ds pop ds popa iret begin: mov ax,0000h mov ds,ax mov di,0070h lea ax,handler cli mov [di],ax mov [di+2],cs sti mov ax,3100h mov dx,(offset begin - offset handler) inc dx int 21h end start

Rok akademicki 2012/2013, Wykład nr 1 46/73 Fortran (FORmula TRANslator) Stworzony w latach 50-tych, ale nadal stosowany Pierwszy kompilator Fortranu był jednocześnie pierwszym w historii kompilatorem języka wysokiego poziomu Standardy języka: Fortran IV (1960), Fortran 66, Fortran 77, Fortran 90, Fortran 95, Fortran 2003, Fortran 2008 Głównym zastosowaniem języka Fortran są obliczenia naukowoinżynierskie (w szczególności obliczenia numeryczne) Dysponuje ogromną liczbę bibliotek, które pozwalają rozwiązać praktycznie każde zadanie numeryczne

Rok akademicki 2012/2013, Wykład nr 1 47/73 Fortran - przykład programu program oblicz_srednia parameter (MaxX=1000) dimension x(maxx) character*80 plik_danych write (*,'(a,$)') "Podaj nazwe pliku danych... " 10 read (*,'(a)') plik_danych open (1,file=plik_danych,status="old",err=20) goto 30 20 write (*,*) & "Blad - ten plik nie istnieje. Podaj nazwe jeszcze raz." goto 10 30 continue read (1,*) N do i=1,n read (1,*) x(i) enddo suma = 0.0 do i=1,n suma = suma+x(i) enddo srednia = suma/n write (*,*) "Srednia wynosi",srednia stop end

Rok akademicki 2012/2013, Wykład nr 1 48/73 BASIC (Beginner All-purpose Symbolic Instruction Code) Opracowany w 1964 roku przez J.G. Kemeny ego i T.E. Kurtza w Darthmouth Collage w oparciu o języki Fortran i Algol-60 Popularny w komputerach 8-bitowych (Atari, ZX Spectrum, Amstrad, Commodore) i kalkulatorach programowanych Występował w wielu wersjach dla różnych komputerów - dla IBM PC jako: GW BASIC, QB, QuickBasic, Visual Basic Brak typów, w pierwszych wersjach numerowanie instrukcji Przykładowe instrukcje: skoku bezwarunkowego: GOTO wywołania podprogramu: GOSUB RETURN warunkowa: IF THEN (ELSE) iteracyjna: FOR NEXT

Rok akademicki 2012/2013, Wykład nr 1 49/73 BASIC - przykłady programów 10 INPUT "What is your name: ", U$ 20 PRINT "Hello "; U$ 30 INPUT "How many stars: ", N 40 S$ = "" 50 FOR I = 1 TO N 60 S$ = S$ + "*" 70 NEXT I 80 PRINT S$ 90 INPUT More stars? ", A$ 100 IF LEN(A$) = 0 THEN 90 110 A$ = LEFT$(A$, 1) 120 IF A$ = "Y" OR A$ = "y" THEN 30 130 PRINT "Goodbye ";U$ 140 END INPUT "What is your name: ", UserName$ PRINT "Hello "; UserName$ DO INPUT "How many stars: ", NumStars Stars$ = STRING$(NumStars, "*") PRINT Stars$ DO INPUT More stars? ", Answer$ LOOP UNTIL Answer$ <> "" Answer$ = LEFT$(Answer$, 1) LOOP WHILE UCASE$(Answer$) = "Y" PRINT "Goodbye "; UserName$ QuickBasic

Rok akademicki 2012/2013, Wykład nr 1 50/73 Pascal Język wysokiego poziomu, ogólnego zastosowania, oparty na Algolu, opracowany w 1970 r. przez Niklausa Wirtha Szczyt popularności przypadał na lata 80-te i początek lat 90-tych Pierwotnie służył celom edukacyjnym do nauki programowania strukturalnego - z tego powodu jest jednym z najszerzej znanych i popularnych języków, zwłaszcza wśród początkujących programistów Zastosowanie w praktyce jest obecnie ograniczone Zalety: czytelność, zwięzłość kodu, rygorystyczna kontrola typów Jedną z popularniejszych implementacji kompilatorów tego języka był Turbo Pascal firmy Borland International

Rok akademicki 2012/2013, Wykład nr 1 51/73 Turbo Pascal Version 7.0 - Borland Inter. Inc. (1992)

Rok akademicki 2012/2013, Wykład nr 1 52/73 Pascal program funkcja; var delta, x1, x2 : real; var a, b, c : real; begin writeln ('Podaj wspolczynniki a, b, c trojmianu kwadratowego: '); readln (a, b, c); delta := (b * b) - (4 * a * c); writeln ('Delta = ', delta); if delta < 0 then writeln('brak MIEJSC ZEROWYCH FUNKCJI!') else if delta > 0 then begin x1 := ((- b) - sqrt(delta)) / (2 * a); x2 := ((- b) + sqrt(delta)) / (2 * a); writeln('x1 = ', x1); writeln('x2 = ', x2); end else begin x1 := (- b) / (2 * a); writeln('x1 = ', x1); end; end.

Rok akademicki 2012/2013, Wykład nr 1 53/73 C++ Obiektowy język programowania zaprojektowany w 1979 roku przez Bjarne a Stroustrupa jako rozszerzenie języka C Nazwa C++ została zaproponowana w 1983 r., wcześniej używano nazwy C z klasami - ++ pochodzi od nazwy operatora inkrementacji C++ zachowuje pełną zgodność z C na poziomie kodu źródłowego Standard ISO/IEC 14882:2011 ( Standard for the C++ Programming Language (C++11) Od początku występowała i wciąż występuje niekompatybilność kompilatorów języka C++ w zakresie obsługiwanej składni C++ nie zmusza programistów do wyboru określonego stylu programowania - w jednym programie można stosować paradygmaty programowania proceduralnego i obiektowego

Rok akademicki 2012/2013, Wykład nr 1 54/73 C++ - nowe elementy względem języka C Programowanie obiektowe: mechanizmy enkapsulacji (funkcje składowe, sekcje prywatne, chronione i publiczne, funkcje zaprzyjaźnione), klasy, obiekty dziedziczenie metody wirtualne (polimorfizm) konstruktory i destruktory operatory new i delete metody i pola statyczne Udogodnienia związane z programowaniem generycznym: szablony (wzorce) klas i funkcji włączenie do biblioteki standardowej generycznej biblioteki STL

Rok akademicki 2012/2013, Wykład nr 1 55/73 C++ - nowe elementy względem języka C Obsługa wyjątków: Inne: przechwytywanie wyjątków: try catch wywoływanie wyjątków: throw przeciążanie funkcji i operatorów funkcje inline przestrzenie nazw i operator zasięgu - ::

Rok akademicki 2012/2013, Wykład nr 1 56/73 C++ - przykład programu cpl.h #include <iostream.h> class Complex { double Re,Im; public: Complex(double,double ); Complex (void); friend istream & operator >> (istream &, Complex &); friend ostream & operator << (ostream &, Complex &); Complex & operator = (Complex &); friend Complex operator + (Complex &,Complex &); };

Rok akademicki 2012/2013, Wykład nr 1 57/73 C++ - przykład programu cpl.cpp #include "cpl.h" Complex::Complex(void) { Re=0; Im=0; } Complex::Complex(double a,double b) { Re=a; Im=b; } Complex operator + (Complex &c,complex &d) { Complex e; e.re=c.re+d.re; e.im=c.im+d.im; return e; } Complex & Complex::operator = (Complex &f) { Re=f.Re; Im=f.Im; return *this; } istream & operator >> (istream &s,complex &g) { s >> g.re; s >> g.im; return s; } ostream & operator << (ostream &s,complex &g) { s << g.re; s << g.im; return s; }

Rok akademicki 2012/2013, Wykład nr 1 58/73 C++ - przykład programu main.cpp #include <iostream.h> #include "cpl.h" void main(void) { Complex a1,a2,a3(3,4); } cout << a3; cin >> a1; cin >> a2; a3 = a1 + a2; cout << a3;

Rok akademicki 2012/2013, Wykład nr 1 59/73 Java Obiektowy język programowania stworzony przez grupę roboczą pod kierunkiem Jamesa Goslinga z firmy Sun Microsystems Programy źródłowe kompilowane są do kodu bajtowego, czyli do postaci wykonywanej przez maszynę wirtualną Podstawowe koncepcje przejęte zostały z języka Smalltalk i C++ Java składa się z szeregu klas definiujących obiekty różnego typu; klasy te pogrupowane są w hierarchicznie ułożone pakiety Podstawowy zestaw klas rozprowadzany jako Java występuje w dwóch wersjach - JRE i JDK: JRE (Java Runtime Environment) - udostępnia bytecode wszystkich klas standardowych i wirtualną maszynę do ich uruchamiania JDK (Java Development Kit) - dodatkowo udostępnia źródła klas oraz dodatkowe narzędzia jak kompilator, paker czy debuger

Rok akademicki 2012/2013, Wykład nr 1 60/73 Java - przykład programu class Person { public String firstname, lastname; public int year; public String PESEL; } public class Proba { public static void main(string[] args) { Person p, q, r; p = new Person(); q = new Person(); r = new Person(); p.firstname = "Jan"; p.lastname = "Kowalski"; p.year = 1981; p.pesel = "81111224350"; } } System.out.println( p.firstname + " " + p.lastname + ", " + p.year + ", PESEL: " + p.pesel );

Rok akademicki 2012/2013, Wykład nr 1 61/73 C# Obiektowy język programowania zaprojektowany pod kierunkiem A. Hejlsberga dla firmy Microsoft w 2001 roku Program napisany w C# kompilowany jest do języka CIL (Common Intermediate Language), specjalnego kodu pośredniego wykonywanego w środowisku uruchomieniowym takim jak.net C# ma wiele cech wspólnych z językami C++ i Java Kolejne wersje: C# 2.0 (2005) C# 3.0 (2007) C# 4.0 (2010) C# 5.0 (2012)

Rok akademicki 2012/2013, Wykład nr 1 62/73 C# - przykład programu using System; public class PrzykladowaKlasa { public static void Main() { string imie; Console.WriteLine("Podaj swoje imie:"); imie=console.readline(); Console.WriteLine("Twoje imie to: " + imie); } } Console.ReadKey();

Rok akademicki 2012/2013, Wykład nr 1 63/73 Borland C++ 3.1 (1992) źródło: forum.codenet.ru/q67485

Rok akademicki 2012/2013, Wykład nr 1 64/73 Borland C++ 3.1 (1992) źródło: jp.progit.pl/

Rok akademicki 2012/2013, Wykład nr 1 65/73 Delphi 1 (1995) źródło: delphi.wikia.com/wiki/delphi_images_(versions)

Rok akademicki 2012/2013, Wykład nr 1 66/73 Borland C++ Builder 1 (1997) źródło: www.blong.com/conferences/borconuk97/c++fordelphi/cbuilder.htm

Rok akademicki 2012/2013, Wykład nr 1 67/73 Microsoft Visual C++ 6.0 (1998)

Rok akademicki 2012/2013, Wykład nr 1 68/73 Borland C++ Builder 6 (2002)

Rok akademicki 2012/2013, Wykład nr 1 69/73 Borland Turbo C++ 2006 Explorer (2006)

Rok akademicki 2012/2013, Wykład nr 1 70/73 Microsoft Visual C++ 2008

Rok akademicki 2012/2013, Wykład nr 1 71/73 Dev-C++ 4.9.9.2

Rok akademicki 2012/2013, Wykład nr 1 72/73 Code::Blocks 10.05

Rok akademicki 2012/2013, Wykład nr 1 73/73 Koniec wykładu nr 1 Dziękuję za uwagę!