-
Data: 2011-02-11 15:22:26
Temat: Re: jak zmusić funkcję rekurencyjną do bycia ogonową (F# byćmoże i OCaml)
Od: Andrzej Jarzabek <a...@g...com> szukaj wiadomości tego autora
[ pokaż wszystkie nagłówki ]On Feb 11, 10:39 am, Jakub Owczarski <j...@g...com>
wrote:
> On Feb 11, 10:15 am, Andrzej Jarzabek <a...@g...com>
> wrote:
>
> Wiem, że to jest zwykła rekurencja, i bardzo chciałbym zobaczyć jak da
> się to przerobić, żeby była ogonowa :)
>
> Wiem, że F# nie jest jakiś super popularny, ale może ktoś zna OCamla,
> podobno są bardzo zbliżone.
Nie znam też zbytnio OCamla, więc nie bij jak coś jest nie tak ze
składnią, ale intencja mam nadzieję będzie czytelna:
let insertSort l =
let rec iter_sort sorted unsorted =
let rec insert lst_less elem lst_rest =
match lst_rest with
| [] -> lst_less:elem
| head::tail -> if head<elem then
insert lst_less:head elem tail
else lst_less::elem::lst_rest
match unsorted with
| [] -> sorted
| head::tail iter_sort (insert [] head sorted) tail
iter_sort [] l
Ogólnie jeśli chodzi o tego typu problemy problemy, to przeczytaj
http://mitpress.mit.edu/sicp/full-text/book/book-Z-H
-11.html#%_sec_1.2.1
W ogóle polecam całą tę książkę jak się chce nauczyć technik
programowania funkcyjnego.
Najnowsze wątki z tej grupy
- TCL - problem z escape ostatniego \ w nawiasach {}
- Nauka i Praca Programisty C++ w III Rzeczy (pospolitej)
- testy-wyd-sort - Podsumowanie
- Tworzenie Programów Nieuprzywilejowanych Opartych Na Wtyczkach
- Do czego nadaje się QDockWidget z bibl. Qt?
- Bibl. Qt jest sztucznie ograniczona - jest nieprzydatna do celów komercyjnych
- Co sciaga kretynow
- AEiC 2024 - Ada-Europe conference - Deadlines Approaching
- Jakie są dobre zasady programowania programów opartych na wtyczkach?
- sprawdzanie słów kluczowych dot. zła
- Re: W czym sie teraz pisze programy??
- Re: (PDF) Surgical Pathology of Non-neoplastic Gastrointestinal Diseases by Lizhi Zhang
- CfC 28th Ada-Europe Int. Conf. Reliable Software Technologies
- Młodzi programiści i tajna policja
- Ada 2022 Language Reference Manual to be Published by Springer
Najnowsze wątki
- 2024-11-08 Belka
- 2024-11-09 pierdolec na punkcie psa
- 2024-11-09 Warszawa => Sales Executive <=
- 2024-11-09 Wrocław => SAP BTP Consultant (mid/senior) <=
- 2024-11-09 Warszawa => ECM Specialist / Consultant <=
- 2024-11-09 Warszawa => Senior Frontend Developer (React + React Native) <=
- 2024-11-10 TVN donosi: Obywatelskie zatrzymanie policjanta (nie na służbie)
- 2024-11-08 Warszawa => Head of International Freight Forwarding Department <=
- 2024-11-08 Warszawa => Key Account Manager <=
- 2024-11-08 Szczecin => Key Account Manager (ERP) <=
- 2024-11-08 Białystok => Full Stack web developer (obszar .Net Core, Angular6+) <
- 2024-11-08 Wrocław => Senior PHP Symfony Developer <=
- 2024-11-08 Warszawa => QA Engineer <=
- 2024-11-08 Warszawa => QA Inżynier <=
- 2024-11-08 Warszawa => Key Account Manager <=