clojure/core iterate

点我查看原文

(ns $clojureDoc.core.iterate)
;; 使用方法 (iterate f x)
;; Returns a lazy sequence of x, (f x), (f (f x)) etc. f must be free of side-effects
;; 返回一个惰性序列:第一项是x,第二项是(f x)的结果,第三项是(f (f x))的结果,即每一次的计算结果参与函数f运算后得到下一项
;; 无副作用:不会读写数据库、文件、socket、以及全局变量等。

(println (take 10 (iterate inc 1)))
;; => (1 2 3 4 5 6 7 8 9 10)

(println (take 10 (iterate (partial + 2) 2)))
;; => (2 4 6 8 10 12 14 16 18 20)

;; nth是从零开始计数,获取元素的本身类型;take按1开始计数,返回和参数类型一样的类型
(println (take 1 '(1 2 3)) (nth '(1 2 3) 1))
;; => (1) 2

;; 斐波那契数列
(def fib (map first (iterate (fn [[a b]] [b (+' a b)]) [0 1])))
;; (iterate (fn [[a b]] [b (+' a b)]) [0 1])
;; 第一项:[0 1]
;; 第二项:[1 1]
;; 第三项:[1 2]
;; 第四项:[2 3]
;; 第五项:[3 5]
;; 第六项:[5 8]
;; map first获得的参数就是 [0 1] [1 1] [1 2] [2 3] [3 5] [5 8] ...
;; map的使用方法是拿每个集合对应项参与函数的运算,故取后面每个集合的第一项:0 1 1 2 3 5 ...
;; 由于iter返回惰性序列,因此take指定前10个,计算10次即可
(println (take 10 fib))
;; => (0 1 1 2 3 5 8 13 21 34)

 

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

zhangningboo

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值