好的,基本上我很难知道选项 1 或 2 是否适用于以下情况:
naturals = 0 : map (+ 1) naturals
选项有:
1. 执行很糟糕,每一步都重新计算所有内容:
naturals = [0]
naturals' = 0:map (+ 1) [0] // == [0, 1]
naturals'' = 0:map (+ 1) [0, 1] // == [0, 1, 2]
naturals''' = 0:map (+ 1) [0, 1, 2] // == [0, 1, 2, 3]
naturals'''' = 0:map (+ 1) [0, 1, 2, 3] // == [0, 1, 2, 3, 4]
2.执行并不糟糕,列表永远是无限的,map
只应用一次
naturals = 0:something
|
naturals' = 0: map (+ 1) (0: something)
|
naturals'' = 0:1: map (+ 1) (0:1: something')
|
naturals''' = 0:1:2: map (+ 1) (0:1:2: something'')
|
naturals'''' = 0:1:2:3:map (+ 1) (0:1:2:3:something''')
|
指示其map
执行的位置。
我确实知道答案可能只有1或2,但我也很感激一些关于共同递归的良好解释的指针,以消除最后的疑问:)