Elementy programowania komputerów
|
|
- Sławomir Niewiadomski
- 7 lat temu
- Przeglądów:
Transkrypt
1 Elementy programowania komputerów 1. Program wykładu 1. Elementy procesu programowania(definiowanie problemu, szkic rozwiązania, wybór i reprezentacja algorytmu, kodowanie, testowanie i usuwanie błędów, dokumentacja, konserwowanie programów) 2. Język potoczny a języki programowania(instrukcja podstawiania, składnia, instrukcje proste i złożone, instrukcje warunkowe, selekcje, schematy: blokowy i Nassiego-Schneidermanna) 3. Arytmetyka komputerowa i jej osobliwości(systemy zliczania, komputerowa reprezentacja liczb, działania na reprezentantach, błędy obliczeń i ich propagacja; Przykłady) 4. Wprowadzenie do budowy elektronicznych układów obliczeniowych(tranzystor MOSFET, bramki logiczne AND, OR, NOT itp, układy liczące: sumatory) 5. Wybrane algorytmy(działania na macierzach, sortowanie tablic, wielomiany, pierwiastki równań algebraicznych). 6. Złożoność algorytmów i ich optymalizacja 7. Języki programowania ze szczególnym uwzględnieniem Pascal-a(C++, Fortran). 8. Struktury danych. 9. Elementy programowania obiektowego(pojęcie klasy lub obiektu, dziedziczenie, procedury wirtualne, obciążanie operatorów) 10. Obliczenia symboliczne(mathematica, Maple, Macsyma) Uzupełnienia: Historia obliczeń i komputerów Gospodarowanie zasobami komputerowymi Ciekawostki ze świata komputerów Obliczenia równoległe i rozproszone Automaty komórkowe, sieci neuronowe, algorytmy genetyczne Logiki wielowartościowe i rozmyte 2.ROCZNICE50lattemu,40lattemu Claude Shannon: praca o teorii informacji 1949 John Bardeen, William Shapley: Tranzystor 1959Feynman:Thereisaplentyroomatthebottom,Wykładotzw.Nanotechnologii, 29.XII.1959, CALTECH. 3. Punkt zaczepienia. Prosty problem. Na wstępie zdefiniujemy to czego będzie dotyczyć wykład Elementy programowania komputerów, który mam prowadzić dla Państwa. Zastanówmy sie na początku jak obliczamy pierwiastki kwadratowe z liczb dodatnich. Ten prosty problem i jego rozwiązanie, które wszyscy znamy, pozwoli nam poczynić pewne uogólnienia i pozwoli dostrzec wszystkie problemy występujące w 1
2 tzw. programowaniu, o którym będziemy mówić. Kiedy już je dostrzeżemy i zauważymy ich ważność poświęcimy kilka chwil każdemu z nich by potem łatwiej i lepiej mócpisaćprogramydlasiebiei,comożeważniejsze,dlainnych,którzybędąjeu Was zamawiać. Zadanie jakie sobie stawiamy brzmi następująco. Dla zadanej liczby dodatniej obliczyć na komputerze(oczywiście bez używania kalkulatora) pierwiastek kwadratowy. Comusimyzrobić?Wczytaćdane,tęjednąliczbę aiwydrukowaćwartość a. Jeśli jest to liczba kwadratowa, tzn. taka, że jej pierwiastek jest liczbą wymierną to sprawa jest w miarę prosta. Co zrobić jednak jeśli liczbą tą jest 2? Pierwiastkiem jest liczba niewymierna. Jak ją przedstawić? Ile miejsc znaczących wydrukować? Jeszcze inaczej, z jaką dokładnością należy ją policzyć? Sześć? Czy dokładność innych obliczeńzależnychodtakwyliczonego a(jeślitakieobliczeniaprowadzimy)będzie wtedy wystarczająca? Itd, itp. Pytań tego typu będzie jeszcze więcej. Musimy na nie odpowiadać gdyż tego wymaga klient, który zamówił u nas program do obliczeń. Jeśli jest to np. bank lub szpital to konsekwencje złych przybliżeń mogą być fatalne wskutkach. Załóżmytymczasem,żewiemyjuż,żedokładnośćmawynosić ±10 6,czyli jedna milionowa. Oznacza to, że wynik jaki dostaniemy może sią różnić od dokładnego o wielkość ǫ = Pojawia się wtedy następny problem jak policzyć ten pierwiastek z taką dokładnością. Żeby nie tracić za wiele czasu spójrzmy na poniższy rysunek. x i+1 =1/2(x +a/x) i i a a a/x 2 x =a Algorytm obliczania pierwiastka jest natychmiastowy! wystarczy liczyć średnią wartość z dwóch liczb: jednej x dowolnej(mniejszej od zadanej liczby a) i drugiej równej drugiemu bokowi a/x. Na początku, przy zadanym x, liczba a/x jest inna niż x, ale jeśli będziemy dostatecznie długo powtarzać proces obliczania średniej to obie liczby będą do siebie dążyć i w nieskończoności iteracji(tak nazywamy ten sposób powtarzania obliczeń) otrzymamy x lim (x i+1 x i ) 0. x Proszętosprawdzić.Przypewnym i = i 0 będziespełnionarelacja x i0 +1 x i0 < ǫ. W tym momencie możemy przerwać proces rachunkowy. Bez tego warunku nasz algorytm byłby nieskończony. Proces obliczeń nigdy by się nie zatrzymał. Mamy więc algorytm obliczeń. Jest to tzw. wzór Herona, znany Państwu. Był używany w szkole. Co najważniejsze, mamy tu algorytm skończony, a więc proces obliczeń możemy w odpowiednim miejscu przerwać. Poobliczeniu adrukujemywynikzdokładnościązadanąprzezklienta. Dokładnie jednak nie wiadomo co drukować. Tak jest. Czy drukować sam pierwiastek, 2
3 czy liczbę i pierwiastek, czy może również wydrukować dokładność, a może też należałoby w jakiś sposób pozwolić ustalać dokładność w trakcie rachowania? Okazuje się, że na te pytania też musimy odpowiedzieć. Musimy te problemy przedyskutować z klientem. To wszystko należy do tzw. definicji problemu. To nie jest już tylko obliczenie pierwiastka, ale obliczenie pierwiastka z zadaną dokładnością i sposób jego przedstawienia. Komputer pracuje stosując tzw. arytmetykę dyskretną, tzn. używa on tylko skończonego zbioru liczb co wynika z jego budowy. Każda komórka pamięci komputera, obojętnie jak duża, może zmieścić prócz tego jakąś liczbę maksymalną i żadnej większej. Jeśli użyjemy większej liczby takich komórek pamięci to możemy używać większych liczb. Wynika stąd, że klient, który zamówił u nas program liczenia pierwiastka powinien dodatkowo określić jak wielkie liczby będą go interesowały. To pozwoli nam zdefiniować wielkość komórek pamięci, w których będziemy zapisywać wyniki obliczeń. Komórki pamięci są podobne pod tym względem do szuflady: większa szuflada(typ danych) większe graty(dane) można tam upchać. Można oczywiście używać maksymalnych dostępnych komórek, ale czasami prowadzi to do zagracenia pamięci. Niektóre problemy nie wymagają by zmuszać naszego klienta do zakupu dodatkowych modułów pamięci do jego komputera. Byłby to nonsens. Czy już rozwiązaliśmy wszystkie problemy? Jeszcze nie. Musimy naszkicować projekt programu. Schemat ten nie będzie jeszcze programem dla komputera, ale pomoże nam wtedy gdy zechcemy taki program napisać. Jak on wygląda? Np. tak 1: ustal dokładność obliczeń epsilon; 2: wczytaj liczbę a; 3: oblicz pierwiastek z liczby a wg wzoru Herona; 4: drukuj pierwiastek; To jest prawdziwy schemat. Spróbujmy go udokładnić. Jak potraktować przypadek ujemnych a? Musimy wczytać nową liczbę a, informując jednocześnie użytkownika o tym, że wprowadził złą daną. Programowanie to przewidywanie różnych sytuacji, które mogą się zdarzyć podczas pracy programu. Lepszy nieco schemat programu może być następujący. 1: ustal dokładność obliczeń: epsilon < ; 2: wczytaj liczbę a; jeśli a<0 wykonaj [ wypisz "a jest mniejsze od 0"; idź do kroku 2 ]; 3: oblicz pierwiastek z liczby a wg wzoru Herona; 4: drukuj pierwiastek; Schemat powoli rozrasta się. Zajmijmy się teraz krokiem 6. Powinniśmy ustalić x,obliczyć a/x,obliczyćśrednią x i = 1/2(x+a/s)ipowtarzaćtenproces,podstawiającpod xnowąwartośćx i ażdomomentugdyosiągniemyżądanądokładność. 1: ustal dokładność obliczeń: epsilon < ; 2: wczytaj liczbę a; jeśli a<0 wykonaj [ wypisz "a jest mniejsze od 0"; idź do kroku 2; ]; 3
4 3: ustal x: x <- a/4; { przyjmujemy startowe x=a/4} I: [ xi <- x; { przechowujemy x również w xi } x <- 1/2 (xi+a/xi); { wyliczamy nowe "x" } jeśli abs(xi-x) > epsilon idź do kroku I; ] 4: drukuj pierwiastek wg wzorca zgodnego z zadaną dokładnością; Używamy tutaj zdań zdań rozkazujących lub ich równoważników: rozkazów. Pojawiły się również rozkazy złożone z kilku linii tekstu instrukcje złożone, które zawarłem w nawiasy kwadratowe[...], etykiety, które są nazwami kroków, pewne funkcje znane w systemie operacyjnym, tzw. funkcje biblioteczne, np. abs, itd. W zasadzie można przystąpić do kodowania. Należy więc wybrać język wyższego poziomu, w którym to kodowanie przeprowadzimy i przełożyć nasz schematyczny program na ten język. Czy to koniec? Rozstrzygnięcie jakiego języka programowanianależyużyćniejestproste.sąichnapewnodziesiątki,amożeisetki.dla przykładu podaję Państwu kod problemu wraz z krótkim opisem oraz przykładem obliczeń, wykonanych w języku Pascal. 1 program heron; (* DOBRA nazwa dla naszego problemu *) 3 uses dos, c r t; (* dolaczanie bibliotek *) 5 (* KOMENTARZ: 7 Program uzywa algorytmu Herona dla znajdowania pierwiastka 9 kwadratowego z liczby z dokladnoscia zadana przez uzytkownika. 11 Jest to metoda iteracyjna, ktora sprowadza sie do wzoru: 13 x_i = 1/2 * (x+a/x), 15 gdzie x jest wartoscia poczatkowa, przypuszczalna wartoscia pierwiastka, ktora moze byc podana przez uzytkownika lub, najlepiej, 17 obliczona wstepnie w programie. 19 Powyzszy wzor mozna latwo zrozumiec analizujac nastepujacy rysunek. (a - pole, x_i - bok, x_(i+1) - drugi bok) a. x_i = a/x x 31 Wartosc pierwiastka lezy gdzies pomiedzy x_i i x_(i+1), a wiec jest 33 rowna 1/2(x_+x_(i+1))=1/2(x_i+a/x_i). 35 Liczba ( a) wczytywana jest z terminala. Dokladnosc obliczen ( eps) jest ustalona przez programiste. 37 *) 4
5 39 const 41 eps=1e-9; (* dokladnosc obliczen; blad *) var 43 x, xi, a: extended; (* duze liczby! *) i t e r : i n t e g e r; (* gospodarka zasobami pamieci *) begin c l r s c r ; 49 (* wczytywanie danych: 51 *) w r i t e l n( Program: HERON ); 53 w r i t e l n( Obliczanie pierwiastka kwadratowego z liczby dodatniej. ); repeat 55 { czytanie danych i sprawdzanie ich poprawnosci } write( Prosze podac liczbe (>0): a= ); 57 u n t i l a>=0; read(a); 59 i f a=0 then 61 begin w r i t e l n; 63 w r i t e l n( Pierwiastek=, 0 ); halt; 65 end; (* 67 obliczenia *) 69 time0:= time; i t e r :=0; 71 x:=a/4; repeat 73 x i:=x; x:=0.5*( x i+axi); 75 i t e r := i t e r +1; u n t i l abs( xi -x) < eps; 77 (* wypisywanie wynikow: 79 Dobrej informacji nigdy za wiele! *) 81 w r i t e l n; 83 w r i t e l n( Liczba: a =,a:25:9); w r i t e l n( Pierwiastek: x =, x i :25:9, +/-,eps); 85 w r i t e l n( Liczba iteracji: iter =, i t e r :25); w r i t e l n( Sprawdzenie: x^2 =, x i*x i :25:9); 87 w r i t e l n( Czas obliczen =,time-time0:25:9, sec. ); end. (* Przykladowe wyniki obliczen Turbo Pascal Version 7.0 Copyright (c) 1983,92 Borland International Program: HERON Obliczanie pierwiastka kwadratowego z liczby dodatniej. 5
6 Prosze podac liczbe (>0): a= Liczba: a = Pierwiastek: x = / E-0009 Liczba iteracji: iter = 30 Sprawdzenie: x^2 = Czas obliczen = sec Co mozna dodac do programu? Np. licznik czasu. *) Schemat słowny progarmu możemy zastąpić schematem graficznym, tzw. schematem blokowym. START eps <- 1e-9 czytaj a a>=0? TAK x <- a/4 NIE drukuj "a jest ujemne" xi <- x x <- 0.5(xi+a/xi) xi-x <=eps NIE TAK drukuj x STOP Jescze innym schematem blokowym, który możemy tutaj zastosować jest tzw. schemat Nassi-Schneidermana. Jego nazwa wywodzi się od nazwisk twórców tego typu schematycznego zapisu programu, lub raczej algorytmu. 6
7 eps <- 1.e-9 a << a >= 0 Tak a=0 Nie x <- 0 x <- a/4 xi <- x x <- 1/2 (xi+a/xi) xi-x <= eps x >> Diagramy Nassi-Schneidermana będą omówione dokładniej w jednym z następnych wykładów. Czego nauczyliśmy się z tego przykładu? Jest to tamat na następny wykład. Możemy tylko powiedzięć, że zdefiniowaliśmy wiele problemów, których na pierwszy rzut oka nie widać, a które zawsze występują w procesie programowania. O nich będą te wykłady. Oszczędziłem Państwu kroku, który jest tutaj konieczny i do którego jeszcze Państwo powrócicie, tzw. uruchamiania programu, a więc jego. Do tego należy jeszcze dodać proces wyłapywania błędów, które towarzyszą każdej pracy. Jak mówi przysłowie, ten nie robi błędów kto nie pracuje. Błedy przypadkowe powstałe w procesie przekładu schematów na język wyższego poziomu będą występowały zawsze. Należyjeusunąćwtejfazieprogramowania.Mogąteżwyśćnajawróżneinnebłędy powstałe wcześniej, błędy koncepcyjne. Możemy podsumować naszą niewiedzę następująco. Wprowadziliśmy i krótko omówiliśmy następujące zagadnienia. definicja problemu stałe(np. ǫlub eps(const) zmienne(np. x, xi)(var) daneiichtypy(type) instrukcja przypisania, podstawiania(<-,:=) instrukcjewarunkowe(jeślitozróbto;;if...then), instrukcja czytania danych(read, readln) instrukcja drukowania danych(write, writeln) proces iteracyjny dokumentacja, komentarze(patrz prawo Eaglesona, niżej) funkcje biblioteczne, biblioteki funkcji i procedur(dos, crt) pamięć dokładność obliczeń, błędy obliczeń algorytm, algorytm skończony kodowanie języki programowania komputerów usuwanie błędów, odpluskwianie(debuging) 7
8 Na zakończenie tej wyliczanki podam pewną prawdę, którą zauważają wszyscy programiści, i która zachęca do komentowania i do pisania dokumentacji programu. Od nazwiska autora będę je nazywał prawem Eaglesona. Brzmi ono tak: Anycodeofyourownthatyouhaven tlookedatforsixormoremonths, might as well been written by someone else. Poprawka do prawa Eaglesona, tym razem innego autorstwa brzmi: Eaglesonisanoptimist,therealnumberismorelikethreeweeks. Trud włożony w zrozumienie tej prawdy pomoże nam uniknąć wielu rozczarowań. Pamiętajmy o tym pisząc nasze, nawet takie proste jak omawiany tutaj, programy. Literatura [1] W.M. Turski: Propedeutyka informatyki, PWN, Warszawa, [2] N. Wirth: Algorytmy + struktury danych = programy, WNT, Warszawa, [3] Ś. Ząbek, Elementy programowania komputerów, UMCS, [4] G. Michael Schneider, Steven W. Weingart, David M. Perlman, Programming and problemsolvingwithpascal,johnwiley&sons,newyork,1982. [5] Cormen, Leiserson, Rivest, Wprowadzenie do algorytmów, WNT, Warszawa, [6] D. E. Knuth, Algorithms, Sci. Am ,(1977). [7] D.E. Knuth, Mathematics and computer science: coping with finiteness, Science, 194, (1976). [8] M. Davis, Czym jest obliczanie, w zbiorze"matematyka współczesna, 12 esejów", red. Lynn Artur Steen, WNT, Warszawa, [9] J. Bielecki, Turbo Pascal, WKŁ, Warszawa, [10] R.K. Kott, Programowanie w języku Pascal, WNT, Warszawa. [11] Lo, Y.M.D., Jui, K.F.C., Wong, S.L. Letter. Science (April 1995):481. [12] M. Sysło,"Trylogia", Warszawa, [13] Robert Ligonniére, Prehistoria i historia komputerów, Ossolineum, Wrocław, [14] Czasopisma komputerowe 8
Problem Herona. lim(x i+1 x i ) 0. lim x i0 +1 x i0 < ǫ.
Problem Herona 1. Prosty problem Na wstępie zdefiniujemy to czego będzie dotyczyć wykład Elementy programowania komputerów, który mam prowadzić dla Państwa. Zastanówmy sie na początku jak obliczamy pierwiastki
wykres funkcji pierwiastki
1. Przykład: REGULA FALSI Literatura: Schneider, Weingart, Perlman, Programming..., Wiley, 1982. Zajmiemy się teraz problemem znajdowania miejsc zerowych jakiejś funkcji f(x). Jest to bardzo stary i ważny
PoniŜej znajdują się pytania z egzaminów zawodowych teoretycznych. Jest to materiał poglądowy.
PoniŜej znajdują się pytania z egzaminów zawodowych teoretycznych. Jest to materiał poglądowy. 1. Instrukcję case t of... w przedstawionym fragmencie programu moŝna zastąpić: var t : integer; write( Podaj
Język programowania PASCAL
Język programowania PASCAL (wersja podstawowa - standard) Literatura: dowolny podręcznik do języka PASCAL (na laboratoriach Borland) Iglewski, Madey, Matwin PASCAL STANDARD, PASCAL 360 Marciniak TURBO
Elżbieta Kula - wprowadzenie do Turbo Pascala i algorytmiki
Elżbieta Kula - wprowadzenie do Turbo Pascala i algorytmiki Turbo Pascal jest językiem wysokiego poziomu, czyli nie jest rozumiany bezpośrednio dla komputera, ale jednocześnie jest wygodny dla programisty,
Algorytm - pojęcie algorytmu, sposób zapisu, poziom szczegółowości, czynności proste i strukturalne. Pojęcie procedury i funkcji.
Algorytm - pojęcie algorytmu, sposób zapisu, poziom szczegółowości, czynności proste i strukturalne. Pojęcie procedury i funkcji. Maria Górska 9 stycznia 2010 1 Spis treści 1 Pojęcie algorytmu 3 2 Sposób
ALGORYTMY. 1. Podstawowe definicje Schemat blokowy
ALGORYTMY 1. Podstawowe definicje Algorytm (definicja nieformalna) to sposób postępowania (przepis) umożliwiający rozwiązanie określonego zadania (klasy zadań), podany w postaci skończonego zestawu czynności
ALGORYTMY. 1. Podstawowe definicje Schemat blokowy
ALGORYTMY 1. Podstawowe definicje Algorytm (definicja nieformalna) to sposób postępowania (przepis) umożliwiający rozwiązanie określonego zadania (klasy zadań), podany w postaci skończonego zestawu czynności
Definicje. Algorytm to:
Algorytmy Definicje Algorytm to: skończony ciąg operacji na obiektach, ze ściśle ustalonym porządkiem wykonania, dający możliwość realizacji zadania określonej klasy pewien ciąg czynności, który prowadzi
TEMAT: Podejmowanie decyzji w programie instrukcja warunkowa (IF).
INFORMATYKA kl. II gimnazjum Krzysztof Gładkowski TEMAT: Podejmowanie decyzji w programie instrukcja warunkowa (IF). Czas: 2godz. Przygotowanie środowiska. Pomoce dydaktyczne. Oprogramowanie środowisko
INFORMATYKA W SZKOLE. Podyplomowe Studia Pedagogiczne. Dr inż. Grażyna KRUPIŃSKA. D-10 pokój 227
INFORMATYKA W SZKOLE Dr inż. Grażyna KRUPIŃSKA grazyna@fis.agh.edu.pl D-10 pokój 227 Podyplomowe Studia Pedagogiczne 2 Algorytmy Nazwa algorytm wywodzi się od nazwiska perskiego matematyka Muhamed ibn
Schematy blokowe I. 1. Dostępne bloki: 2. Prosty program drukujący tekst.
Schematy blokowe I Jeżeli po schematach blokowych będzie używany język C, to należy używać operatorów: '&&', ' ', '!=', '%' natomiast jeśli Ruby to 'and', 'or', '%', '!='. 1. Dostępne bloki: a) początek:
Algorytm. Krótka historia algorytmów
Algorytm znaczenie cybernetyczne Jest to dokładny przepis wykonania w określonym porządku skończonej liczby operacji, pozwalający na rozwiązanie zbliżonych do siebie klas problemów. znaczenie matematyczne
1 Wprowadzenie do algorytmiki
Teoretyczne podstawy informatyki - ćwiczenia: Prowadzący: dr inż. Dariusz W Brzeziński 1 Wprowadzenie do algorytmiki 1.1 Algorytm 1. Skończony, uporządkowany ciąg precyzyjnie i zrozumiale opisanych czynności
Wykład II PASCAL - podstawy składni i zmienne, - instrukcje wyboru, - iteracja, - liczby losowe
Podstawy programowania Wykład II PASCAL - podstawy składni i zmienne, - instrukcje wyboru, - iteracja, - liczby losowe 1 I. Składnia Składnia programu Program nazwa; Uses biblioteki; Var deklaracje zmiennych;
Algorytm. a programowanie -
Algorytm a programowanie - Program komputerowy: Program komputerowy można rozumieć jako: kod źródłowy - program komputerowy zapisany w pewnym języku programowania, zestaw poszczególnych instrukcji, plik
Wykład IV Algorytmy metody prezentacji i zapisu Rzut oka na język PASCAL
Studia Podyplomowe INFORMATYKA Podstawy Informatyki Wykład IV Algorytmy metody prezentacji i zapisu Rzut oka na język PASCAL 1 Część 1 Pojęcie algorytmu 2 I. Pojęcie algorytmu Trochę historii Pierwsze
ECDL Podstawy programowania Sylabus - wersja 1.0
ECDL Podstawy programowania Sylabus - wersja 1.0 Przeznaczenie Sylabusa Dokument ten zawiera szczegółowy Sylabus dla modułu Podstawy programowania. Sylabus opisuje, poprzez efekty uczenia się, zakres wiedzy
Algorytmika i pseudoprogramowanie
Przedmiotowy system oceniania Zawód: Technik Informatyk Nr programu: 312[ 01] /T,SP/MENiS/ 2004.06.14 Przedmiot: Programowanie Strukturalne i Obiektowe Klasa: druga Dział Dopuszczający Dostateczny Dobry
Programowanie w Turbo Pascal
Skróty: ALT + F9 Kompilacja CTRL + F9 Uruchomienie Struktura programu: Programowanie w Turbo Pascal Program nazwa; - nagłówek programu - blok deklaracji (tu znajduje się VAR lub CONST) - blok instrukcji
Wykład II PASCAL - podstawy składni i zmienne, - instrukcje wyboru, - iteracja cz. 1
Podstawy programowania Wykład II PASCAL - podstawy składni i zmienne, - instrukcje wyboru, - iteracja cz. 1 1 I. Składnia Składnia programu Program nazwa; Uses biblioteki; Var deklaracje zmiennych; Begin
Scenariusz lekcji. podać przykłady zalet użycia takiej instrukcji; opisać algorytm obliczania średniej n liczb;
1 TEMAT LEKCJI: Instrukcja pętli For w języku Turbo Pascal 2 CELE LEKCJI: 2.1 Wiadomości: Uczeń potrafi: podać konstrukcję instrukcji pętli For w języku Turbo Pascal; omówić sposób działania instrukcji
WHILE (wyrażenie) instrukcja;
INSTRUKCJE ITERACYJNE WHILE, DO WHILE, FOR Instrukcje iteracyjne pozwalają powtarzać daną instrukcję programu określoną liczbę razy lub do momentu osiągnięcia określonego skutku. Pętla iteracyjna while
Wstęp do informatyki- wykład 2
MATEMATYKA 1 Wstęp do informatyki- wykład 2 Systemy liczbowe 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
a[1] a[2] a[3] a[4] a[5] a[6] a[7] a[8] a[9] a[10] 3-2 5 8 12-4 -26 12 45-76
. p. 1 Algorytmem nazywa się poddający się interpretacji skończony zbiór instrukcji wykonania zadania mającego określony stan końcowy dla każdego zestawu danych wejściowych W algorytmach mogą występować
CIĄGI wiadomości podstawowe
1 CIĄGI wiadomości podstawowe Jak głosi definicja ciąg liczbowy to funkcja, której dziedziną są liczby naturalne dodatnie (w zadaniach oznacza się to najczęściej n 1) a wartościami tej funkcji są wszystkie
Zapisywanie w wybranej notacji algorytmów z warunkami i iteracyjnych
Temat 2. Zapisywanie w wybranej notacji algorytmów z warunkami i iteracyjnych Cele edukacyjne Usystematyzowanie podstawowych pojęć: algorytm z warunkami, iteracja, algorytm iteracyjny, zmienna sterująca.
WHILE (wyrażenie) instrukcja;
INSTRUKCJE ITERACYJNE WHILE, DO WHILE, FOR Instrukcje iteracyjne pozwalają powtarzać daną instrukcję programu określoną liczbę razy lub do momentu osiągnięcia określonego skutku. Pętla iteracyjna while
1. Nagłówek funkcji: int funkcja(void); wskazuje na to, że ta funkcja. 2. Schemat blokowy przedstawia algorytm obliczania
1. Nagłówek funkcji: int funkcja(void); wskazuje na to, że ta funkcja nie ma parametru i zwraca wartość na zewnątrz. nie ma parametru i nie zwraca wartości na zewnątrz. ma parametr o nazwie void i zwraca
1 Całki funkcji wymiernych
Całki funkcji wymiernych Definicja. Funkcją wymierną nazywamy iloraz dwóch wielomianów. Całka funkcji wymiernej jest więc postaci: W (x) W (x) = an x n + a n x n +... + a x + a 0 b m x m + b m x m +...
Programowanie i techniki algorytmiczne
Temat 2. Programowanie i techniki algorytmiczne Realizacja podstawy programowej 1) wyjaśnia pojęcie algorytmu, podaje odpowiednie przykłady algorytmów rozwiązywania różnych 2) formułuje ścisły opis prostej
Instrukcje podsumowanie. Proste: - przypisania - wejścia-wyjścia (read, readln, write, writeln) - pusta - po prostu ; (średnik) Strukturalne:
Instrukcje podsumowanie Proste: - przypisania - wejścia-wyjścia (read, readln, write, writeln) - pusta - po prostu ; (średnik) Strukturalne: - grupująca end - warunkowa if
Rzut oka na współczesną matematykę spotkanie 3: jak liczy kalkulator i o źródłach chaosu
Rzut oka na współczesną matematykę spotkanie 3: jak liczy kalkulator i o źródłach chaosu P. Strzelecki pawelst@mimuw.edu.pl Instytut Matematyki, Uniwersytet Warszawski MISH UW, semestr zimowy 2011-12 P.
Algorytmy i struktury danych. Wykład 4
Wykład 4 Różne algorytmy - obliczenia 1. Obliczanie wartości wielomianu 2. Szybkie potęgowanie 3. Algorytm Euklidesa, liczby pierwsze, faktoryzacja liczby naturalnej 2017-11-24 Algorytmy i struktury danych
Zajęcia: VBA TEMAT: VBA PROCEDURY NUMERYCZNE Metoda bisekcji i metoda trapezów
Zajęcia: VBA TEMAT: VBA PROCEDURY NUMERYCZNE Metoda bisekcji i metoda trapezów W ramach zajęć oprogramujemy jedną, wybraną metodę numeryczną: metodę bisekcji numerycznego rozwiązywania równania nieliniowego
Programowanie strukturalne i obiektowe. Funkcje
Funkcje Często w programach spotykamy się z sytuacją, kiedy chcemy wykonać określoną czynność kilka razy np. dodać dwie liczby w trzech miejscach w programie. Oczywiście moglibyśmy to zrobić pisząc trzy
Technologie informacyjne - wykład 12 -
Zakład Fizyki Budowli i Komputerowych Metod Projektowania Instytut Budownictwa Wydział Budownictwa Lądowego i Wodnego Politechnika Wrocławska Technologie informacyjne - wykład 12 - Prowadzący: Dmochowski
Podstawy programowania
Podstawy programowania Część trzecia sterujące wykonaniem programu wprowadzenie Autor Roman Simiński Kontakt roman.siminski@us.edu.pl www.us.edu.pl/~siminski Niniejsze opracowanie zawiera skrót treści
Technologia informacyjna Algorytm Janusz Uriasz
Technologia informacyjna Algorytm Janusz Uriasz Algorytm Algorytm - (łac. algorithmus); ścisły przepis realizacji działań w określonym porządku, system operacji, reguła komponowania operacji, sposób postępowania.
ALGORYTMY I PROGRAMY
ALGORYTMY I PROGRAMY Program to ciąg instrukcji, zapisanych w języku zrozumiałym dla komputera. Ten ciąg instrukcji realizuje jakiś algorytm. Algorytm jest opisem krok po kroku jak rozwiązać problem, czy
Algorytmy i schematy blokowe
Algorytmy i schematy blokowe Algorytm dokładny przepis podający sposób rozwiązania określonego zadania w skończonej liczbie kroków; zbiór poleceń odnoszących się do pewnych obiektów, ze wskazaniem porządku,
Zapisywanie algorytmów w języku programowania
Temat C5 Zapisywanie algorytmów w języku programowania Cele edukacyjne Zrozumienie, na czym polega programowanie. Poznanie sposobu zapisu algorytmu w postaci programu komputerowego. Zrozumienie, na czym
Informacja w perspektywie obliczeniowej. Informacje, liczby i obliczenia
Informacja w perspektywie obliczeniowej Informacje, liczby i obliczenia Cztery punkty odniesienia (dla pojęcia informacji) ŚWIAT ontologia fizyka UMYSŁ psychologia epistemologia JĘZYK lingwistyka nauki
1. Informatyka - dyscyplina naukowa i techniczna zajmująca się przetwarzaniem informacji.
Temat: Technologia informacyjna a informatyka 1. Informatyka - dyscyplina naukowa i techniczna zajmująca się przetwarzaniem informacji. Technologia informacyjna (ang.) Information Technology, IT jedna
Wstęp do Informatyki zadania ze złożoności obliczeniowej z rozwiązaniami
Wstęp do Informatyki zadania ze złożoności obliczeniowej z rozwiązaniami Przykład 1. Napisz program, który dla podanej liczby n wypisze jej rozkład na czynniki pierwsze. Oblicz asymptotyczną złożoność
Wykład z Podstaw Informatyki dla I roku BO. Piotr Mika
Wykład z Podstaw Informatyki dla I roku BO Piotr Mika Napisanie programu komputerowego: Zasada rozwiązania zadania Stworzenie sekwencji kroków algorytmu Przykłady algorytmów z życia codziennego (2/1 6)
O systemach liczbowych
O systemach liczbowych 1. Systemy liczbowe Literatura:Turski,Propedeutyka...;Skomorowski,... 1.1. Dwójkowy system pozycyjny W dziesiętnym systemie pozycyjnym ciąg cyfr 321.23 oznacza liczbę 3 10 2 +2 10
ALGORYTMY Algorytm poprawny jednoznaczny szczegółowy uniwersalny skończoność efektywność (sprawność) zmiennych liniowy warunkowy iteracyjny
ALGORYMY Algorytm to przepis; zestawienie kolejnych kroków prowadzących do wykonania określonego zadania; to uporządkowany sposób postępowania przy rozwiązywaniu zadania, problemu, z uwzględnieniem opisu
Ile waży arbuz? Copyright Łukasz Sławiński
Ile waży arbuz? Arbuz ważył7kg z czego 99 % stanowiła woda. Po tygodniu wysechł i woda stanowi 98 %. Nieważne jak zmierzono te %% oblicz ile waży arbuz teraz? Zanim zaczniemy, spróbuj ocenić to na wyczucie...
Maciej Piotr Jankowski
Reduced Adder Graph Implementacja algorytmu RAG Maciej Piotr Jankowski 2005.12.22 Maciej Piotr Jankowski 1 Plan prezentacji 1. Wstęp 2. Implementacja 3. Usprawnienia optymalizacyjne 3.1. Tablica ekspansji
Podstawy Informatyki. Inżynieria Ciepła, I rok. Wykład 7 Algorytmy
Podstawy Informatyki Inżynieria Ciepła, I rok Wykład 7 Algorytmy Programowanie Sformułowanie problemu. Opracowanie metodyki rozwiązania. Opracowanie algorytmu. Napisanie kodu źródłowego (zakodowanie) w
Języki programowania zasady ich tworzenia
Strona 1 z 18 Języki programowania zasady ich tworzenia Definicja 5 Językami formalnymi nazywamy każdy system, w którym stosując dobrze określone reguły należące do ustalonego zbioru, możemy uzyskać wszystkie
2.8. Algorytmy, schematy, programy
https://app.wsipnet.pl/podreczniki/strona/38766 2.8. Algorytmy, schematy, programy DOWIESZ SIĘ co oznaczają pojęcia: algorytm, schemat blokowy, język programowania, jakie są sposoby obliczania największego
Geometria analityczna
Geometria analityczna Paweł Mleczko Teoria Informacja (o prostej). postać ogólna prostej: Ax + By + C = 0, A + B 0, postać kanoniczna (kierunkowa) prostej: y = ax + b. Współczynnik a nazywamy współczynnikiem
Algorytm poprawny jednoznaczny szczegółowy uniwersalny skończoność efektywność (sprawność) zmiennych liniowy warunkowy iteracyjny
Algorytm to przepis; zestawienie kolejnych kroków prowadzących do wykonania określonego zadania; to uporządkowany sposób postępowania przy rozwiązywaniu zadania, problemu, z uwzględnieniem opisu danych
Podstawy programowania. Wykład: 13. Rekurencja. dr Artur Bartoszewski -Podstawy programowania, sem 1 - WYKŁAD
Podstawy programowania Wykład: 13 Rekurencja 1 dr Artur Bartoszewski -Podstawy programowania, sem 1 - WYKŁAD Podstawy programowania Rekurencja - pojęcie 2 Rekurencja - pojęcie Rekurencja (rekursja) wywołanie
Algorytm. Słowo algorytm pochodzi od perskiego matematyka Mohammed ibn Musa al-kowarizimi (Algorismus - łacina) z IX w. ne.
Algorytm znaczenie cybernetyczne Jest to dokładny przepis wykonania w określonym porządku skończonej liczby operacji, pozwalający na rozwiązanie zbliżonych do siebie klas problemów. znaczenie matematyczne
Algorytmy, reprezentacja algorytmów.
Algorytmy, reprezentacja algorytmów. Wprowadzenie do algorytmów Najważniejszym pojęciem algorytmiki jest algorytm (ang. algorithm). Nazwa pochodzi od nazwiska perskiego astronoma, astrologa, matematyka
Podstawy i języki programowania
Podstawy i języki programowania Laboratorium 1 - wprowadzenie do przedmiotu mgr inż. Krzysztof Szwarc krzysztof@szwarc.net.pl Sosnowiec, 16 października 2017 1 / 25 mgr inż. Krzysztof Szwarc Podstawy i
Opis efektów kształcenia dla modułu zajęć
Nazwa modułu: Formalne podstawy informatyki Rok akademicki: 2013/2014 Kod: EIB-1-220-s Punkty ECTS: 2 Wydział: Elektrotechniki, Automatyki, Informatyki i Inżynierii Biomedycznej Kierunek: Inżynieria Biomedyczna
KARTA KURSU. Wstęp do programowania
KARTA KURSU Nazwa Nazwa w j. ang. Wstęp do programowania Introduction to Programming Kod Punktacja ECTS* 6 Koordynator dr inż. Magdalena Andrzejewska Zespół dydaktyczny: dr inż. Magdalena Andrzejewska
Temat 20. Techniki algorytmiczne
Realizacja podstawy programowej 5. 1) wyjaśnia pojęcie algorytmu, podaje odpowiednie przykłady algorytmów rozwiązywania różnych problemów; 2) formułuje ścisły opis prostej sytuacji problemowej, analizuje
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:
Języki i metodyka programowania
Języki i metodyka programowania www.ee.pw.edu.pl/~slawinsm Dr inż. Maciej Sławiński M.Slawinski@ee.pw.edu.pl GE518l Konsultacje: śr. 13 00-13 45 SK201/GE518l pt. 10 15-11 00 GE518l/SK201 Algorytmika Literatura
Algorytm. Krótka historia algorytmów
Algorytm znaczenie cybernetyczne Jest to dokładny przepis wykonania w określonym porządku skończonej liczby operacji, pozwalający na rozwiązanie zbliżonych do siebie klas problemów. znaczenie matematyczne
3. FUNKCJA LINIOWA. gdzie ; ół,.
1 WYKŁAD 3 3. FUNKCJA LINIOWA FUNKCJĄ LINIOWĄ nazywamy funkcję typu : dla, gdzie ; ół,. Załóżmy na początek, że wyraz wolny. Wtedy mamy do czynienia z funkcją typu :.. Wykresem tej funkcji jest prosta
PRZEWODNIK PO PRZEDMIOCIE
Nazwa przedmiotu: Kierunek: Informatyka Rodzaj przedmiotu: obowiązkowy w ramach treści wspólnych z kierunkiem Matematyka, moduł kierunku obowiązkowy PODSTAWY INFORMATYKI Fundamentals of computer science
Podstawy Informatyki. Inżynieria Ciepła, I rok. Iteracja warunkowadopóki(while) Blok instrukcji. Pascal: begin instrukcja1; C: { end;
Podstawy Informatyki Inżyria Ciepła, I rok Wykład 8 Algorytmy, cd Instrukcja decyzyjna wybierz Zda wybierz służy do wyboru jednej z kilku możliwości Ma ono postać: wybierz przełącznik z wartość_1: zda_1
W wielu obliczeniach w matematyce bądź fizyce wykonanie niektórych kroków zależy od spełnienia warunku.
W wielu obliczeniach w matematyce bądź fizyce wykonanie niektórych kroków zależy od spełnienia warunku. Nie wolno dzielić przez zero i należy sprawdzić, czy dzielna nie jest równa zeru. W dziedzinie liczb
Wstęp do programowania
Wstęp do programowania Literatura David Harel. Rzecz o istocie informatyki. Algorytmika. Wydawnictwa Naukowo-Techniczne. Wydanie trzecie. Seria: Klasyka informatyki. Warszawa 2000. Niklaus Wirth. Algorytmy
Iteracje. Algorytm z iteracją to taki, w którym trzeba wielokrotnie powtarzać instrukcję, aby warunek został spełniony.
Iteracje Algorytm z iteracją to taki, w którym trzeba wielokrotnie powtarzać instrukcję, aby warunek został spełniony. Iteracja inaczej zwana jest pętlą i oznacza wielokrotne wykonywanie instrukcji. Iteracje
5. Rozwiązywanie układów równań liniowych
5. Rozwiązywanie układów równań liniowych Wprowadzenie (5.1) Układ n równań z n niewiadomymi: a 11 +a 12 x 2 +...+a 1n x n =a 10, a 21 +a 22 x 2 +...+a 2n x n =a 20,..., a n1 +a n2 x 2 +...+a nn x n =a
Proste algorytmy w języku C
Proste algorytmy w języku C Michał Rad AGH Laboratorium Maszyn Elektrycznych 2016-12-01 Outline Język C Zadanie pierwsze - obliczanie miejsc zerowych wielomianu Zadanie drugie - znajdowanie największego
Specyfikacja zadania informatycznego nr 1
INFORMATYCZNE ROZWIĄZYWANIE PROBLEMÓW Specyfikacja zadania informatycznego nr 1 Cele projektu Opis potrzeby wykonania zadania Środek informatyczny Reprezentacja obiektu System ekspertowy Procedury Heurystyki
Programowanie komputerów
Programowanie komputerów Wykład 1-2. Podstawowe pojęcia Plan wykładu Omówienie programu wykładów, laboratoriów oraz egzaminu Etapy rozwiązywania problemów dr Helena Dudycz Katedra Technologii Informacyjnych
Aproksymacja diofantyczna
Aproksymacja diofantyczna Szymon Draga Ustroń, 4 listopada 0 r Wprowadzenie Jak wiadomo, każdą liczbę niewymierną można (z dowolną dokładnością) aproksymować liczbami wymiernymi Powstaje pytanie, w jaki
Programowanie strukturalne. Opis ogólny programu w Turbo Pascalu
Programowanie strukturalne Opis ogólny programu w Turbo Pascalu STRUKTURA PROGRAMU W TURBO PASCALU Program nazwa; } nagłówek programu uses nazwy modułów; } blok deklaracji modułów const } blok deklaracji
Poprawność algorytmów
Poprawność algorytmów Jeśli uważasz, że jakiś program komputerowy jest bezbłędny, to się mylisz - po prostu nie zauważyłeś jeszcze skutków błędu, który jest w nim zawarty. Jakie błędy można popełnić? Błędy
Metody numeryczne Technika obliczeniowa i symulacyjna Sem. 2, EiT, 2014/2015
Metody numeryczne Technika obliczeniowa i symulacyjna Sem. 2, EiT, 2014/2015 1 Metody numeryczne Dział matematyki Metody rozwiązywania problemów matematycznych za pomocą operacji na liczbach. Otrzymywane
ALGORYTMY I STRUKTURY DANYCH
KATEDRASYSTEMÓWOBLICZENIOWYCH ALGORYTMY I STRUKTURY DANYCH 1.Rekurencja Rekurencja inaczej rekursja (ang. recursion) to wywołanie z poziomu metody jej samej. Programowanie z wykorzytaniem rekurencji pozwala
O LICZBACH NIEOBLICZALNYCH I ICH ZWIĄZKACH Z INFORMATYKĄ
O LICZBACH NIEOBLICZALNYCH I ICH ZWIĄZKACH Z INFORMATYKĄ Jakie obiekty matematyczne nazywa się nieobliczalnymi? Jakie obiekty matematyczne nazywa się nieobliczalnymi? Najczęściej: a) liczby b) funkcje
O ALGORYTMACH I MASZYNACH TURINGA
O ALGORYTMACH I MASZYNACH TURINGA ALGORYTM (objaśnienie ogólne) Algorytm Pojęcie o rodowodzie matematycznym, oznaczające współcześnie precyzyjny schemat mechanicznej lub maszynowej realizacji zadań określonego
Metody numeryczne w przykładach
Metody numeryczne w przykładach Bartosz Ziemkiewicz Wydział Matematyki i Informatyki UMK, Toruń Regionalne Koło Matematyczne 8 kwietnia 2010 r. Bartosz Ziemkiewicz (WMiI UMK) Metody numeryczne w przykładach
Instrukcja warunkowa i złoŝona.
Instrukcja warunkowa i złoŝona. Budowa pętli warunkowej. JeŜeli mielibyśmy przetłumaczyć instrukcję warunkową to brzmiałoby to mniej więcej tak: jeŝeli warunek jest spełniony, to wykonaj jakąś operację
1. LICZBY DZIAŁ Z PODRĘCZNIKA L.P. NaCoBeZu kryteria sukcesu w języku ucznia
L.P. DZIAŁ Z PODRĘCZNIKA NaCoBeZu kryteria sukcesu w języku ucznia 1. LICZBY 1. Znam pojęcie liczby naturalne, całkowite, wymierne, dodatnie, ujemne, niedodatnie, odwrotne, przeciwne. 2. Potrafię zaznaczyć
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
Algorytm. Słowo algorytm pochodzi od perskiego matematyka Mohammed ibn Musa al-kowarizimi (Algorismus - łacina) z IX w. ne.
Algorytm znaczenie informatyczne Jest to dokładny przepis wykonania w określonym porządku skończonej liczby operacji, pozwalający na rozwiązanie zbliżonych do siebie klas problemów. znaczenie matematyczne
Luty 2001 Algorytmy (7) 2000/2001 s-rg@siwy.il.pw.edu.pl
System dziesiętny 7 * 10 4 + 3 * 10 3 + 0 * 10 2 + 5 *10 1 + 1 * 10 0 = 73051 Liczba 10 w tym zapisie nazywa się podstawą systemu liczenia. Jeśli liczba 73051 byłaby zapisana w systemie ósemkowym, co powinniśmy
4. Funkcje. Przykłady
4. Funkcje Przykłady 4.1. Napisz funkcję kwadrat, która przyjmuje jeden argument: długość boku kwadratu i zwraca pole jego powierzchni. Używając tej funkcji napisz program, który obliczy pole powierzchni
Scenariusz lekcji opartej na programie Program nauczania informatyki w gimnazjum DKW-4014-87/99
Scenariusz lekcji opartej na programie Program nauczania informatyki w gimnazjum DKW-4014-87/99 Techniki algorytmiczne realizowane przy pomocy grafiki żółwia w programie ELI 2,0. Przedmiot: Informatyka
Zapis algorytmów: schematy blokowe i pseudokod 1
Zapis algorytmów: schematy blokowe i pseudokod 1 Przed przystąpieniem do napisania kodu programu należy ten program najpierw zaprojektować. Projekt tworzącego go algorytmu może być zapisany w formie schematu
Wykład I Cyfrowa reprezentacja informacji Algorytmy metody prezentacji i zapisu Tablice (wstęp) Rzut okiem na języki programowania
Podstawy programowania Wykład I Cyfrowa reprezentacja informacji Algorytmy metody prezentacji i zapisu Tablice (wstęp) Rzut okiem na języki programowania 1 dr Artur Bartoszewski - Podstawy programowania,
Wstęp do informatyki. Maszyna RAM. Schemat logiczny komputera. Maszyna RAM. RAM: szczegóły. Realizacja algorytmu przez komputer
Realizacja algorytmu przez komputer Wstęp do informatyki Wykład UniwersytetWrocławski 0 Tydzień temu: opis algorytmu w języku zrozumiałym dla człowieka: schemat blokowy, pseudokod. Dziś: schemat logiczny
Algorytmika i programowanie. dr inż. Barbara Fryc Wyższa Szkoła Informatyki i Zarządzania w Rzeszowie
Algorytmika i programowanie dr inż. Barbara Fryc Wyższa Szkoła Informatyki i Zarządzania w Rzeszowie Algorytmy i sposoby ich przedstawiania Algorytm - informatyczny opis planu rozwiązania zadania Sposoby
Algorytmy. Programowanie Proceduralne 1
Algorytmy Programowanie Proceduralne 1 Przepis Warzenie piwa Brunświckiego Programowanie Proceduralne 2 Przepis Warzenie piwa Brunświckiego składniki (dane wejściowe): woda, słód, itd. wynik: beczka piwa
Laboratorium 5 Przybliżone metody rozwiązywania równań nieliniowych
Uniwersytet Zielonogórski Wydział Informatyki, Elektrotechniki i Telekomunikacji Instytut Sterowania i Systemów Informatycznych Elektrotechnika niestacjonarne-zaoczne pierwszego stopnia z tyt. inżyniera
Podstawy programowania. Wykład 3 Konstrukcje sterujące. Krzysztof Banaś Podstawy programowania 1
Podstawy programowania. Wykład 3 Konstrukcje sterujące Krzysztof Banaś Podstawy programowania 1 Kod źródłowy i wykonanie programu Kod źródłowy w języku programowania zawiera przepis wykonania programu
PASCAL. Etapy pisania programu. Analiza potrzeb i wymagań (treści zadania) Opracowanie algorytmu Kodowanie Kompilacja Testowanie Stosowanie
PASCAL Język programowania wysokiego poziomu Opracowany przez Mikołaja Wirtha na początku lat 70 XX wieku Prosty, z silną kontrolą poprawności Stosowany prawie wyłącznie na uczelniach do nauki programowania
Algorytmy. Programowanie Proceduralne 1
Algorytmy Programowanie Proceduralne 1 Przepis Warzenie piwa Brunświckiego Programowanie Proceduralne 2 Przepis Warzenie piwa Brunświckiego składniki (dane wejściowe): woda, słód, itd. wynik: beczka piwa
if (wyrażenie ) instrukcja
if (wyrażenie ) instrukcja Jeśli wartość wyrażenia jest różna od zera, to jest wykonywana instrukcja, jeśli wartość wyrażenia jest równa 0, to dana instrukcja nie jest wykonywana Wyrażenie testowe podajemy