Zdefiniuj funkcję ZAMIANA :ls, której parametrem jest lista słów składających się z małych liter alfabetu łacińskiego (bez polskich znaków). Wartością funkcji będzie lista składająca się z jedno- lub dwuelementowych list, powstałych z poszczególnych słów listy będącej parametrem, w następujący sposób:
Oto przykładowe wyniki:
ZAMIANA [kalinka malinka] | powinno dać wynik [[a 2] [a 2]] |
---|---|
ZAMIANA [procedura w logo] | powinno dać wynik [[o 1] [0] [o 2]] |
ZAMIANA [abrakadabra hokus pokus] | powinno dać wynik [[a 5] [o 1] [o 1]] |
Ze względu na fakt, że właściwy kod będzie konwertował każdy wyraz oddzielnie to funkcja ZAMIANA będzie tylko wywoływać funkcję pomocniczą i zbierać wyniki.
(2.) Przygotuj listę wynikową. (3.) Dla każdego wyrazu (4.) pobierz wynik i dopisz do listy wynikowej. (6.) Zwróć listę wynikową.
Funkcja ZAMIANA_wyraz przyjmuje jeden argument :w - wyraz do zamiany. Na koniec funkcja zwraca listę, która zawiera najczęściej występującą samogłoskę. Przedstawiony poniżej kod można zooptymalizować poprzez usuwanie znalezionych samogłosek z wyrazu, ale wtedy kod stałby się mniej przejrzysty.
(2.) Przyjmij, że nie ma samogłosek i (3.) zadeklaruj zmienną :znak, która w dalszej części będzie przyjmował znak samogłoski o ile jakaś samogłoska występuje. (4.) Dla każdej litery, która (5.) jest samogłoską: (6.) zadekalaruj zmienną :maxl zliczajacą ilość wystąpień samogłoski i (7.) zapamietaj numer aktualnie przeglądanego znaku. (8. - 12.) Szukaj od danego miejsca do końca wyrazu pozostałych wystąpień znalezionej samogłoski. (13.) Jeśli dana samogłoska ma więcej wystąpień niż dotychczas znaleziona to (14. - 15.) zapamiętaj dane. Użyty tutaj znak większości > gwarantuje, że jeśli będą dwie samogłoski po tyle samo wystąpień to zwrócona zostanie pierwsza znaleziona samogłoska. (19.) Sprawdź czy znaleziono samogłoskę. Jeśli tak to (20.) zwróć listę znak, ilość wystąpień. W przeciwnym razie (21.) zwróć listę z wartością 0.
Zdefiniuj funkcję LICZNP :liczba, której wartością jest lista liczbowa, zawierająca zliczenie kolejnych nieparzystych cyfr parametru będącego dowolną liczbą naturalną. Każdy element listy wynikowej mówi, ile kolejnych ("jedna za drugą") cyfr nieparzystych, ograniczonych cyframi parzystymi, początkiem, bądź końcem liczby, napotykamy w zapisie dziesiętnym parametru :liczba. Oto przykładowe wyniki:
LICZNP 1233501 | powinno dać w wyniku [1 3 1] |
---|---|
LICZNP 90 | powinno dać w wyniku [1] |
LICZNP 2200 | powinno dać w wyniku listę pustą, czyli [] |
Zadanie to można rozwiązać analizując po kolei kolejne cyfry. W każdej iteracji znaleziony znak ma sprawdzaną parzystość. W przypadku, gdy jest nieparzysty i poprzednia też była nieparzysta to zwiększa licznik. Jednak jeśli cyfra jest parzysta, a poprzednia nie to należy dopisać licznik na koniec listy. Problem może sprawić liczba bez parzystej na początku. Z tego powodu w algorytmie nawet jeśli liczba wyniesie 0 to jest wykonywane wcześniej wspomniane równanie.
Przygotuj zmienną (2.) pod listę wynikową, (3.) do zliczania wystąpień cyfr nieparzystych. (4.) Ze względu na fakt, że zwracanie wyniku przerywa wykonywanie programu, a nie znamy (i nie chcemy) znać długości cyfry to (5.) program działa wewnątrz nieskończonej pętli. (7.) Jeśli wykryta cyfra jest nieparzysta oraz licznik jest różny od zera, czyli wcześniej zostały znalezione cyfry nieparzyste, to (8.) dopisz liczbę do listy wynikowej i (9.) zresetuj licznik. (11.) Jeśli następna cyfra jest nieparzysta to (12.) zwiększ :licznik. (14.) Jeśli po sprawdzeniach okazuje się, że liczba to 0 to: (15.) zwróć listę wynikową. Jeśli jednak nie to przejdź do następnej iteracji (17.) wpierw usuwając ostatnią cyfrę z liczby.
Napisz procedurę GLIZDAWCE :ls, która rysuje odpowiedni rysunek wężyków. Parametrem procedury jest lista składająca się ze słów złożonych z małych i wielkich liter alfabetu łacińskiego (bez polskich znaków). Przy tym:
Przykładowo GLIZDAWCE [Warszawski Konkurs Informatyczny] powinno narysować następujący rysunek:
Chociaż nie jest to wymagane warto rozpisać kod na kilka procedur. W ten sposób łatwiej będzie poprawić wybraną część kodu. W przedstawionym rozwiązaniu funkcja GLIZDAWCE oblicza wymiary rysunku i go rysuje, GLIZDAWCE_kolor zwraca kolor w zależności od znaku, GLIZDAWCE_RYS - rysuje pojedynczy symbol, a GLIZDAWCE_słowo rysuje cały wyraz.
Pisanie programu najlepiej zacząć od najprotszej funkcji: GLIZDAWCE_kolor, która przyjmuje jeden argument :litera. (2.) Jeśli :litera jest samogłoską to (3.) zwraca biały kolor. (4.) W przeciwnym szary.
Cały rysunek składa się z jednego symbolu narsowanego wiele razy. Funkcja GLIZDAWCE_RYS pozwala dostosować wysokość symbolu (nie długość jego boku) argumentem :h. Ponadto funkcja przyjmuje argument :kierunek, który określa orientację symbolu (0 każdy parzysty symbol w słowie, a 1 każdy nieparzysty) oraz :kolor - kolor wypełnienia symbolu.
Wylicz (2.) bok sześciokąt na boku kwadratu i (3.) bok sześciokąta nie leżącego na obramowaniu kwadratu. (4. - 8.) Jeśli narysowany ma być symbol dla znaku o indeksie nieparzystym to odpowiednio przesuń żółwia. (9. - 19.) Narysuj symbol i (20. - 24.) sprawdź czy żółw nie musi wykonać dodatkowego przesunięcia.
Do rysowania całego pojedynczego słowa można wykorzystac procedurę GLIZDAWCE_słowo, która przyjmuje dwa argumenty :h - wysokość pierwszego symbolu oraz :w - wyraz do przeanalizowania.
(2.) Narysuj duży symbol i (3. - 6.) przesuń żółwia do lewego dolnego rogu następnego rysunku. (7.) Dla każdej pozostałej litery: (8.) rysuj symbol o odpowiednim kierunku u kolorze. Wykorzystywane są do tego funkcje GLIZDAWCE_RYS oraz GLIZDAWCE_kolor. Potem (9. - 12.) przesuń dalej. Po zakończeniu rysowania (14. - 17.) wróć tam skąd została rozpoczęta procedura.
Dotychczas dopisany kod potrafi narysować dowolne słowo i odpowiednio dostosować wysokości symboli oraz kolory. Główna funkcja GLIZDAWCE ma teraz dwa zadania: wyliczyć wysokości symboli, a nastepnie je narysować.
Określ maksymalną (2.) wysokość i (3.) szerokosć rysunku. (4.) Oblicz wysokość symbolu na podstawie wysokości. Następnie (5. - 10.) znajdź nadłuższy wyraz i (11.) sprawdź czy rysunek zmieści się na szerokość. Jeśli nie to (12.) oblicz wymiary symbolu na podstawie szerokości rysunku. W kolejnym etapie procoedury (14. - 17.) przejdź do rysowania i (18. - 23.) Narysuj wszystkie wyrazy.