|
|
|
[Haskell] Хвостовая рекурсия, почему так
|
|||
|---|---|---|---|
|
#18+
Тут 11001713 всплыла тема, копирую сюда FishHookZyK_BotaN, Код: plaintext 1. 2. 3. 4. 5. 6. 7. 8. 9. 10. 11. 12. 13. ----------------------------------------- 36 /e Код: plaintext 1. 2. 3. 4. 5. 6. 7. 8. 9. 10. 11. 12. 13. 14. 15. 16. 17. Installing executable(s) in C:\Users\Smirnov\AppData\Roaming\cabal\bin ----------------------------------------- 36 /e!!!!!!! Почему не происходит присвоение sumt [] acc=0?? Почему неправильный код работает правильно?? ... |
|||
|
:
Нравится:
Не нравится:
|
|||
| 20.07.2011, 17:25 |
|
||
|
[Haskell] Хвостовая рекурсия, почему так
|
|||
|---|---|---|---|
|
#18+
FishHook, это не присвоение, а объявление ... |
|||
|
:
Нравится:
Не нравится:
|
|||
| 20.07.2011, 20:57 |
|
||
|
[Haskell] Хвостовая рекурсия, почему так
|
|||
|---|---|---|---|
|
#18+
FishHook, используется сопоставление с образцом http://learnyouahaskell.com/syntax-in-functions#pattern-matching ... |
|||
|
:
Нравится:
Не нравится:
|
|||
| 20.07.2011, 20:58 |
|
||
|
[Haskell] Хвостовая рекурсия, почему так
|
|||
|---|---|---|---|
|
#18+
FishHook, Тут нет и одного присваивания Код: plaintext 1. 2. 3. 4. 5. 6. 7. 8. 9. 10. 11. Порядок вычисления примерно такой 1. вызывается sum a [1, 2, 3, 4, 5 6, 7, 8] 2. sum вызщывает sumt от a и нуля 3. в sumt ищется подходящий шаблон аргументов, 3.1 [] acc не подходит - список не пуст, 3.1 (h:t) acc подходит - список состоит из головы (первого элемента) - h и хвоста (всех остальных элементов) t 4. вызывается вариант для данного шаблона в первой итерации это будет sumt t acc+h t = [2, 3, 4, 5, 6, 7, 8] acc = 0 h = 1 соответственно для уже этого вызова acc = 0+1 = 1 то есть дальше идет в пункт 3 только с новыми значениями аргументов, пока первый шаблн с пустым списком не подойдет прочитайте про pattern matching http://www.rsdn.ru/article/haskell/haskell_part1.xml ... |
|||
|
:
Нравится:
Не нравится:
|
|||
| 20.07.2011, 21:02 |
|
||
|
|

start [/forum/moderation_log.php?user_name=%D0%9E%D1%81%D0%B0%D1%80]: |
0ms |
get settings: |
9ms |
get forum list: |
23ms |
get settings: |
10ms |
get forum list: |
19ms |
check forum access: |
5ms |
check topic access: |
5ms |
track hit: |
201ms |
get topic data: |
10ms |
get first new msg: |
6ms |
get forum data: |
2ms |
get page messages: |
56ms |
get tp. blocked users: |
2ms |
| others: | 705ms |
| total: | 1053ms |

| 0 / 0 |
