-
Data: 2012-07-26 17:41:54
Temat: Re: Wam wszytskim odbilo z tym Lispem :)
Od: Adam Przybyla <a...@r...pl> szukaj wiadomości tego autora
[ pokaż wszystkie nagłówki ]Piotr Chamera <p...@p...onet.pl> wrote:
> W dniu 2012-07-26 16:31, Adam Przybyla pisze:
>> Piotr Chamera <p...@p...onet.pl> wrote:
>>> W dniu 2012-07-26 11:18, Adam Przybyla pisze:
>>>> Piotr Chamera <p...@p...onet.pl> wrote:
>>>>> W dniu 2012-07-26 10:29, AK pisze:
>>>>>> Użytkownik "Piotr Chamera" <p...@p...onet.pl> napisał:
>>>>>>> (setq r
>>>>>>> (let* ((a 8)
>>>>>>> (b (+ a 7))
>>>>>>> (c 12)
>>>>>>> (d 2))
>>>>>>> (* (+ a b) (- c d))))
>>> ...
>>>>>>> A teraz może podaj odpowiednik tego kodu w Pythonie,
>>>>>>> bo to poniżej to nie jest to samo:
>>> r = (lambda:
>>> a = 8
>>> b = a + 7
>>> c = 12
>>> d = 2
>>> return (a + b) * (c - d))()
>> ... nie do konca, to trzeba troche rozumiec jak to dziala w lispie w oparciu
>> o rachunek lambda, poprawne rozwiazanie, dla konstrukcji let* wyglada tak:
>> r=(lambda a: (lambda b: (lambda c: (lambda d: (a + b) * (c -
d))(d=2))(c=12))(b=a+7))(a=8)
>
> Dzięki, to mi trochę rozjaśniło...
> W moim zapisie potraktowałem ,,lambdę" jako po prostu anonimowy analog
> do ,,def" (tak jakbym tworzył normalną pythonową funkcję, tylko bez
> nazwy - a czegoś takiego w języku nie ma). Nie pomyślałem, żeby
> naprawdę rozpisać to za pomocą tej ,,rzeczywiście dostępnej" w języku
> lambdy. W tym wypadku, ponieważ b, c i d są niezależne, można to nawet
> trochę skrócić:
... tz jak zmienisz zadanie, to rozwiazanie jest takie jak podales:
>
> r=(lambda a: (lambda b, c, d: (a + b) * (c - d))(b=a+7, c=12, d=2))(a=8)
>
> będzie to analogiczne do
>
> (setq r (let ((a 8))
> (let ((b (+ a 7))
> (c 12)
> (d 2))
> (* (+ a b) (- c d)))))
Zgadza sie w 100%;-) Z powazaniem
Adam Przybyla
Następne wpisy z tego wątku
- 26.07.12 18:04 Piotr Chamera
- 26.07.12 20:41 bartekltg
- 26.07.12 21:28 PK
- 26.07.12 22:11 Andrzej Jarzabek
- 26.07.12 22:49 Andrzej Jarzabek
- 27.07.12 12:02 AK
- 27.07.12 12:43 Piotr M Kuć
- 27.07.12 22:01 slawek
- 28.07.12 01:02 Andrzej Jarzabek
- 28.07.12 21:12 Marek Borowski
- 28.07.12 22:17 Przemek O
- 28.07.12 22:44 A.L.
- 28.07.12 23:16 Edek Pienkowski
- 28.07.12 23:20 Edek Pienkowski
- 29.07.12 00:12 A.L.
Najnowsze wątki z tej grupy
- "Wuj dobra rada" z KDAB rozważa: Choosing the Right Programming Language for Your Embedded Linux Device
- Nowa ustawa o ochronie praw autorskich - opis problemu i szkic ustawy
- Alg. kompresji LZW
- Popr. 14. Nauka i Praca Programisty C++ w III Rzeczy (pospolitej)
- Arch. Prog. Nieuprzywilejowanych w pełnej wer. na nowej s. WWW energokod.pl
- 7. Raport Totaliztyczny: Sprawa Qt Group wer. 424
- 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?
Najnowsze wątki
- 2025-03-22 OT Silnik sie przegrzewa
- 2025-03-22 Przenoszenie przez wifi na nowego Androida
- 2025-03-22 Warszawa => Senior Account Manager <=
- 2025-03-22 Wrocław => Konsultant wdrożeniowy Comarch XL (Logistyka, WMS, Produk
- 2025-03-22 Warszawa => Spedytor Międzynarodowy <=
- 2025-03-22 Warszawa => NMS System Administrator <=
- 2025-03-22 Warszawa => Analityk IT (projekty z obszaru telco) <=
- 2025-03-22 Orzeczenie TSUE
- 2025-03-22 Warszawa => Operations Support Systems (OSS) Team Leader <=
- 2025-03-22 Warszawa => Scrum Master <=
- 2025-03-22 Warszawa => Senior Account Manager <=
- 2025-03-22 Warszawa => BI Developer / Analityk BI <=
- 2025-03-22 Warszawa => IT Recruiter <=
- 2025-03-21 Zakaz wjazdu
- 2025-03-21 Nie zawsze wchodzi jedynka