Programowanie funkcyjne/Strumienie/Ćwiczenia
Z Studia Informatyczne
Przejdź do nawigacjiPrzejdź do wyszukiwaniaPraca domowa
- Zdefiniuj strumień silni.
- Zdefiniuj przeplot elementów dwóch strumieni, tzn. strumień powstały z ułożenia naprzemian elementów danych strumieni. [można to zrobić sprytnie, zamieniając w wywołaniu rekurencyjnym miejscami argumenty.]
- Dany jest nieskończony strumień liczb . Jego strumień różnicowy, to strumień postaci: . Strumień różnicowy drugiego stopnia, to strumień różnicowy strumienia różnicowego. Ogólniej, strumień różnicowy -tego stopnia polega na -krotnym wzięciu strumienia różnicowego, zaczynając od . Zdefiniuj, w sposób uwikłany, strumień złożony z pierwszych elementów strumieni różnicowych kolejnych stopni .
Ćwiczenia
Zdefiniuj strumienie i narysuj schematy odpowiadające tym definicjom:
- Zdefiniuj procedurę for_each, która wykonuje zadaną procedurę na kolejnych elementach strumienia.
- Zdefiniuj procedurę print_int_stream wypisującą elementy strumienia liczb całkowitych.
- Użyj do tego celu procedury for_each z poprzedniego zadania.
- strumień wszystkich par (uporządkowanych) elementów z dwóch danych strumieni (w dowolnej kolejności),
- strumień liczb całkowitych, które w rozkładzie na liczby pierwsze mają tylko 2, 3 i 5 [R.Hamming],
- Zdefiniuj w sposób uwikłany strumień, którego -ty wyraz jest równy .
- Zdefiniuj w sposób uwikłany strumień złożony z tych dodatnich liczb całkowitych, które w rozkładzie na czynniki pierwsze mają tylko liczby 2 i 3, oraz rozkładają się na nieparzystą liczbę czynników pierwszych.
- szereg potęgowy
- pochodną,
- całkę,
- interpolacje wybranych funkcji (np.: , , , ),
- mnożenie szeregów potęgowych,
- Niech
- Korzystając z wyników poprzedniego zadania zaimplementuj dzielenie szeregów potęgowych.
możemy reprezentować jako strumień jego kolejnych współczynników; przy takiej implementacji szeregów potęgowych zaimplementuj: