1 / 28

Algorytmy i algorytmika Opracowanie: Maciej Karanowski

Algorytmy i algorytmika Opracowanie: Maciej Karanowski. ALGORYTMY I ALGORYTMIKA. Najważniejsze pojęcia. Historia algorytmów. Co należy koniecznie wiedzieć?. Sposoby przedstawiania algorytmów. Sprawdź się!. Poznajmy najważniejsze pojęcia.

gage-bauer
Download Presentation

Algorytmy i algorytmika Opracowanie: Maciej Karanowski

An Image/Link below is provided (as is) to download presentation Download Policy: Content on the Website is provided to you AS IS for your information and personal use and may not be sold / licensed / shared on other websites without getting consent from its author. Content is provided to you AS IS for your information and personal use only. Download presentation by click this link. While downloading, if for some reason you are not able to download a presentation, the publisher may have deleted the file from their server. During download, if you can't get a presentation, the file might be deleted by the publisher.

E N D

Presentation Transcript


  1. Algorytmy i algorytmikaOpracowanie: Maciej Karanowski

  2. ALGORYTMY I ALGORYTMIKA Najważniejsze pojęcia Historia algorytmów Co należy koniecznie wiedzieć? Sposoby przedstawiania algorytmów Sprawdź się! Algorytmy

  3. Poznajmy najważniejsze pojęcia... Mimo, że słowo „algorytm”brzmi trochę obco, to jednak okazuje się, że pod nim kryje się nasz dobry znajomy! Definicja mówi: Algorytm jest to precyzyjny opis sposobu rozwiązania określonego zadania lub osiągnięcia jakiegoś celu. Rozumiem! Algorytmy

  4. Poznajmy najważniejsze pojęcia... A l g o r y t m i k a jest działem informatyki zajmującym się poszukiwaniem, konstruowaniem i badaniem własności algorytmów w kontekście ich przydatności do rozwiązywania problemów za pomocą komputerów. Trzeba to przemyśleć! Algorytmy

  5. Kilka słów o historii algorytmów Pojęcie algorytm pochodzi od brzmienia fragmentu nazwiska arabskiego matematyka Muhammada ibn Musa al.- Chorezmiego, uznawanego za prekursora obliczeniowych metod w matematyce. Żył na przełomie VIII i IX wieku i to on upowszechnił system dziesiętny i stosowanie zera jako symbolu oznaczającego „nic”. Algorytmy

  6. Kilka słów o historii algorytmów W historii informatyki można spotkać wiele śladów poszukiwania sposobów rozwiązywania problemów nazywanych algorytmami. To głównie matematycy dążyli do wynalezienia maszyny, która wykonywałaby czasochłonne i żmudne obliczenia. Najstarsze odnalezione przyrządy do liczenia tzw.abakusy pochodzą z X w. p.n.e. Później powstały liczydła, jedno z takich liczydeł, używanych do dziś w Japonii, to soroban widoczny obok na zdjęciu. Algorytmy

  7. Kilka słów o historii algorytmów Jednym z najstarszych i najbardziej znanych algorytmów jest algorytmEuklidesa, który podany został już 2500 lat temu. Algorytm ten służy do obliczania największego dzielnika dwóch liczb (ale nie ma nic wspólnego z rozkładem liczb na czynniki pierwsze) i należy obecnie do kanonu wiedzy informatycznej. Wydaje się, że każdy informatyk powinien znać zasadę działania tego algorytmu. Algorytmy

  8. Co należy koniecznie wiedzieć? Z algorytmami w szkole po raz pierwszy spotykasz się na lekcjach matematyki, kiedy stosujesz pewien sposób rozwiązania zadania np. algorytm pisemnego mnożenia dwóch dowolnych liczb. Czy potrafisz sformułować przepis na obliczenie iloczynu dwóch liczb sposobem pisemnym? Algorytm jest pojęciem ściśle związanym z informatyką, a każdy program komputerowy jest zapisem pewnego algorytmu (wyrażonym w określonym języku programowania). Algorytmy

  9. Co należy koniecznie wiedzieć? Wykonawcą algorytmu może być komputer lub człowiek. Każdy problem, który ma być rozwiązany musi zostać najpierw poddany s p e c y f i k a c j i, która polega na dokładnym opisie zadania. W ramach specyfikacji problemu podaje się: • d a n e dla rozwiązywanego problemu • w a r u n k i, jakie te dane muszą spełniać • w y n i k i z w a r u n k a m i, jakie muszą one spełniać • z w i ą z e k w y n i k ó w z d a n y m i Algorytmy

  10. Sposoby przedstawiania algorytmów Opis słowny Lista kroków Schemat blokowy Zapis z wykorzystaniem jednego z języków programowania Algorytmy

  11. Opis słowny algorytmu Często w codziennym życiu masz do czynienia z sytuacją, w której przekazujesz komuś przepis na wykonanie jakiegoś zadania czy dojścia do określonego celu. Jeżeli jest to przepis, który precyzyjnie określa kolejne czynności i w jednoznaczny sposób pozwala dojść do celu, to właśnie posługujesz się opisem słownym algorytmu. Algorytmy

  12. Algorytm w postaci listy kroków 1. Podejdź do telefonu 2. Podnieś słuchawkę 3. Sprawdź, czy jest sygnał... 4. ... Zapewne domyślasz się – jest to początek algorytmu wykonania telefonu podany w postacilisty kroków Zobacz teżalgorytm Euklidesa Pamiętaj by w jednym punkcie (kroku) opisać t y l k o j e d n ą o p e r a c j ę Algorytmy

  13. Algorytm w postaci schematu blokowego Schemat blokowy jest graficzną reprezentacją słownego zapisu algorytmu Elementy, z których buduje się schematy blokowe poznasz przeglądając kolejne slajdy Muszę je koniecznie obejrzeć Algorytmy

  14. Podstawowe klocki schematu blokowego KLOCKI GRANICZNE Stop Używany do zakończenia algorytmu (zwykle jeden, można używać kilku - algorytm ma wtedy mniej ścieżek i jest bardziej przejrzysty) Start Używany do rozpoczęcia algorytmu (tylko jeden) Algorytmy

  15. KLOCKI WEJŚCIA I WYJŚCIA podaj wartość Służy do wprowadzania danych (wartości) z zewnątrz wyprowadź wartość Służy do wyprowadzania danych Algorytmy

  16. KLOCEK WYKONAWCZY instrukcje do wykonania W tym klocku można umieszczać jedną lub kilka instrukcji. Korzysta się z instrukcji przypisania(:=) i operatorów arytmetycznych(+; -; *; /; ^) Algorytmy

  17. KLOCEK WARUNKOWY wyrażenie logiczne Tak Nie Klocek ten ma jedno wejście i dwa wyjścia. Pytamy np. czy lewa strona jest równa prawej(a=b). Otrzymujemy odpowiedź TAK lub NIE i wychodzimy jednym z wyjść. Nie ma znaczenia po której stronie jest znak Tak lub Nie. W klocku warunkowym umieszcza się tylko jedno wyrażenie logiczne. Wyrażenie logiczne budujemy za pomocą operatora logicznego, inaczej znaku relacji(=; <; >; <=; >=; <>) Algorytmy

  18. Algorytm przedstawiony w języku programowania Aby przedstawić algorytm w postaci programu (czyli zapisany w języku programowania) trzeba go zbudować z ciągu instrukcji określonego języka programowania. Tyle tych języków... Który wybrać? Może Pascal, albo C++ lub Logo... Algorytmy

  19. Sprawdź się! W zadaniach umieszczonych na kolejnych slajdach należy wskazywać elementy, które powinny być kolejno dołączane do schematu blokowego. Muszę się zastanowić! Algorytmy

  20. START Obliczanie sumy dwóch liczb Pisz sumę Podaj (a) STOP Podaj (b) S=: a + b Algorytmy

  21. START Obliczanie sumy dwóch liczb Podaj (a) STOP S=: a + b Pisz sumę Podaj (b) Algorytmy

  22. START Obliczanie sumy dwóch liczb Podaj (a) Podaj (b) Pisz sumę S=: a + b STOP Algorytmy

  23. START Obliczanie sumy dwóch liczb Podaj (a) Podaj (b) S=: a + b Pisz sumę STOP Algorytmy

  24. START Obliczanie sumy dwóch liczb Podaj (a) Podaj (b) S=: a + b Pisz sumę STOP Algorytmy

  25. Obliczanie sumy dwóch liczb START Podaj (a) Znakomicie! Podaj (b) S=: a + b Pisz sumę STOP Algorytmy

  26. Przykład schematu blokowego Przykład 1 Start BUDOWA ALGORYTMU: START - podaj liczbę a,- oblicz kwadrat liczby a,- oblicz sześcian liczby a,- podaj wartość kwadratu liczby a,- podaj sześcian liczby a. STOP a:= Podaj liczbę a2:=a*a a3:=a*a*a a2:= a3:= Stop Algorytmy

  27. Przykład schematu blokowego Przykład 2 Start WYJRZYJ PRZEZ OKNO TAK CZY PADA DESZCZ? NIE WEŹ PARASOL WYJDŹ Stop Algorytmy

  28. Pomysł Euklidesa na obliczanie NWD 1. Dane są dwie niezerowe liczby naturalne a i b. 2. Dopóki liczby nie są równe powtarzaj krok 3, w przeciwnym razie przejdź do kroku 4. 3. Od większej liczby odejmij mniejszą i tę większą zastąp otrzymaną różnicą. 4. Wyprowadź wynik: NWD (największy wspólny dzielnik) jest równy pierwszej liczbie. Wiem, że to jest lista kroków Powrót do listy kroków Powrót do historii Algorytmy

More Related