1 / 23

Algorytmy 1

Algorytmy 1. Definicja algorytmu Sposoby przedstawiania algorytmów Rodzaje skrzynek wykorzystywanych w zapisie blokowym Rodzaje algorytmów. Definicja algorytmu. Algorytm jest to precyzyjny opis sposobu rozwiązania określonego zadania lub osiągnięcia jakiegoś celu.

mikko
Download Presentation

Algorytmy 1

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 1 • Definicja algorytmu • Sposoby przedstawiania algorytmów • Rodzaje skrzynek wykorzystywanych w zapisie blokowym • Rodzaje algorytmów

  2. Definicja algorytmu Algorytm jest to precyzyjny opis sposoburozwiązania określonego zadania lub osiągnięcia jakiegoś celu.

  3. Występują następujące sposoby przedstawiania algorytmów: • Słowny na ogół mało dokładny. • Lista kroków. • Schemat blokowy.

  4. Algorytm opisujący zadanie:„Czytaj definicję tak długo, aż nauczysz się jej na pamięć(przedstawiony w postaci listy kroków) • Przeczytaj definicję. 2 Czy umiesz ją na pamięć? a) jeśli tak, przejdź do kroku 3 b) jeśli nie, przejdź do kroku 1. 3. Gratulacje, nauczyłeś się definicji na pamięć.

  5. Algorytm opisujący zadanie:„Czytaj definicję tak długo, aż nauczysz się jej na pamięć(przedstawiony w postaci schematu blokowego) Start PRZECZYTAJ DEFINICJĘ CZY UMIESZ DEFINICJĘ NA PAMIĘĆ TAK NIE GRATULACJE, NAUCZYŁEŚ SIĘ DEFINICJI NA PAMIĘĆ STOP

  6. Start Start Start Start Start STOP STOP STOP STOP STOP SKRZYNKI GRANICZNE PRZECZYTAJ DEFINICJĘ PRZECZYTAJ DEFINICJĘ PRZECZYTAJ DEFINICJĘ PRZECZYTAJ DEFINICJĘ SKRZYNKI INSTRUKCJI CZY UMIESZ DEFINICJĘ NA PAMIĘĆ CZY UMIESZ DEFINICJĘ NA PAMIĘĆ CZY UMIESZ DEFINICJĘ NA PAMIĘĆ SKRZYNKI WARUNKU SKRZYNKI WEJŚCIA / WYJŚCIA GRATULACJE, NAUCZYŁEŚ SIĘ DEFINICJI NA PAMIĘĆ GRATULACJE, NAUCZYŁEŚ SIĘ DEFINICJI NA PAMIĘĆ

  7. Rodzaje algorytmów ALGORYTMY REKURENCYJNE LINIOWE SEKWENCYJNE WARUNKOWE ITERACYJNE

  8. Algorytm sekwencyjny (liniowy) • Algorytm liniowy (sekwencyjny) — instrukcje wykonywane są po kolei (w porządku, w jakim zostały wprowadzone). Przykład algorytmu linowego – przepis na jajecznicę. • 1. Przygotuj jajko, tłuszcz, przyprawy2. Wrzuć tłuszcz na patelnię3. Podgrzej patelnię4. Wbij jajko5. Dodaj przyprawy6. Wymieszaj7. Wyłóż na talerz

  9. Algorytmy z rozgałęzieniami • Algorytmy z rozgałęzieniami to coś podobnego do algorytmów liniowych, z tym, że są różne drogi (rozgałęzienia) do uzyskania wyniku - inaczej mówiąc, algorytm wykonywany jest w zależności od pewnych warunków. Przykład algorytmu z rozgałęzieniami – „Sprawdź czy pada deszcz, jeśli tak, weź kurtkę z kapturem” 1. Wyjrzyj przez okno 2. Czy pada deszcz? a) jeśli tak, przejdź do kroku 3 b) Jeśli nie, przejdź do kroku 4 3 Weź kurtkę z kapturem 4 Wyjdź

  10. Algorytm iteracyjny Rodzaj algorytmu w którym wielokrotnie wykonuje się pewne instrukcje, dopóki nie zostanie spełniony określony warunek Przykład algorytmu iteracyjnego – Sprawdzaj co „jakiś czas” jakie jest światło, jeśli jest czerwone czekaj, jeśli jest zielone przejdź 1. Stój2. Czy świeci się czerwone światło?         A. Jeśli TAK to przejdź do kroku 1         B. Jeśli NIE to przejdź do kroku 33. Można przejść przez ulicę zachowując ostrożność

  11. Algorytm rekurencyjny • Algorytm rekurencyjny to taki, który w pewnym kroku zawiera polecenie wykonania siebie samego dla innych danych. Przykład rekurencji. Algorytm „jedz kaszkę” • 1. Jedz kaszkę  (weź łyżkę kaszki i połknij)         2. Jedz kaszkę dalej, aż talerz będzie pusty

  12. Przykłady różnych algorytmów

  13. Wyszukiwanie najmłodszego ucznia w klasie. Lista kroków. Dane: Uczniowie. Wynik: Najmłodszy uczeń Krok 1 Przyjmij, że najmłodszym uczniem w klasie jest pierwszy w kolejności Zapamiętaj jego imię. Krok 2 Jeśli zadałeś pytanie już wszystkim uczniom, to koniec algorytmu, najmłodszym jest zapamiętany uczeń. Krok 3 Przejdź do kolejnego ucznia i zapytaj go, kiedy się urodził. Jeśli urodził się później niż najmłodszy z dotychczas pytanych, to zapamiętaj jego dane. Krok 4 Wróć do kroku 2, by kontynuować zadawanie pytań

  14. Schemat blokowy algorytmu

  15. Opis w postaci listy kroków algorytmu wyszukującego wybrany element w zbiorze uporządkowanym Dane: Uporządkowany zbiór elementów. Wyróżniony element, który się w nim znajduje. Wynik : Miejsce wyróżnionego elementu w zbiorze 1. Sprawdź środkowy element zbioru 2. Jeśli jest on wyróżnionym elementem to zakończ poszukiwania. 3.Jeśli środkowy element jest większy od poszukiwanego , to pozostaw zbiór na lewo od elementu środkowego, a w przeciwnym razie (czyli gdy środkowy element jest mniejszy od poszukiwanego), pozostaw zbiór na prawo od elementu środkowego, 4. Wróć do kroku 1

  16. Schemat blokowy algorytmu wyszukującego wybrany element w zbiorze uporządkowanym

  17. Algorytm określający, która z dwóch podanych liczb jest mniejsza Dane: Liczby x i y Lista kroków: • Początek algorytmu • Wprowadź liczby x i y • Sprawdź warunek, czy liczba x jest mniejsza od y • Jeśli jest mniejsza to: min:=x, w przeciwnym razie: min:=y • Wyprowadź wartość min • Koniec algorytmu

  18. Algorytm określający, która z dwóch podanych liczb jest mniejsza Start Wprowadź (x, y) X<Y TAK NIE min:=y min:=x Dane: Liczby x i y Schemat blokowy: Wyprowadź min STOP

  19. Algorytm dodawania dwóch liczb Dane: Liczby a i b Lista kroków: • Początek algorytmu • Wprowadź liczby a i b • Oblicz wartość x:=a+b • Wyprowadź wartość x • Koniec algorytmu

  20. Algorytm dodawania dwóch liczb Start Wprowadź (a, b) x:=a+b Dane: Liczby a i b Schemat blokowy: Wyprowadź x STOP

  21. Opis w postaci listy kroków na przykładzie algorytmu wyszukującego największą z 4 liczb

  22. Opis w postaci schematu blokowego

  23. Koniec

More Related