Paradygmaty programowania/Ćwiczenia 12: Programowanie funkcyjne w Haskellu III

Z Studia Informatyczne
Wersja z dnia 13:25, 7 sie 2006 autorstwa Pitab (dyskusja | edycje)
(różn.) ← poprzednia wersja | przejdź do aktualnej wersji (różn.) | następna wersja → (różn.)
Przejdź do nawigacjiPrzejdź do wyszukiwania

Zadanie 1

Napisać definicję leniwego operatora alternatywy na liczbach całkowitych, nie korzystając ze standardowego operatora ||.

Wskazówka:

Zadanie 2

Zapisać za pomocą wyrażeń z kwalifikatorem listę trójek pitagorejskich (czyli liczb naturalnych x,y, z takich, że Parser nie mógł rozpoznać (błąd składni): {\displaystyle x^2 + y^2 = z^2<math>) z ustalonego zakresu. Chodzi zatem o funkcję o sygnaturze: ''trójkipit :: Integer -> [(Integer, Integer, Integer)]'' Dla danego <math>n} powinna ona stworzyć listę wszystkich trójek pitagorejskich, których elementy należą do przedziału [1...n].

Wskazówka:

Zadanie 3

Jak zmienić program z poprzedniego zadania, by nie wypisywał niepotrzebnie podobnych trójek, np. (3, 4, 5) i (4, 3, 5)?

Wskazówka:

Zadanie 4

Napisać funkcję lsilnia, która dla danego n1 wygeneruje listę silni liczb od 1 do n. Przykładowo, wywołanie lsilnia 4 ma dać listę [1, 2, 6, 24]. Jak zrobić to efektywnie?

Wskazówka:

Zadanie 5*

Zdefiniować operator >> za pomocą >>=.

Wskazówka:

Zadanie 6

Co się stanie przy poniższych wywołaniach? Sprawdź...

 getChar >>= return
 return ’a’ >>= putChar
Wskazówka: