题解 | #求斐波那契(Fibonacci)数列的第 n 项#Erlang实现前后关系

求斐波那契(Fibonacci)数列的第 n 项

http://www.nowcoder.com/questionTerminal/fc2815c6222a4684afb0b5b70f33c320

解题思路

实现题目的前后关系即可

代码

-spec fib(N :: integer()) -> integer().
fib(N) ->
    do_fib(2, #{0 => 0, 1 => 1}, N).

do_fib(Index, Map, N) when Index =< N ->
    Val = maps:get(Index - 1, Map) + maps:get(Index - 2, Map),
    do_fib(Index + 1, Map#{Index => Val}, N);
do_fib(_, Map, N) ->
    maps:get(N, Map).
全部评论

相关推荐

05-20 21:57
已编辑
门头沟学院 Java
喜欢吃卤蛋的悲伤蛙在提需求:建信融通没消息吧,我2说有实习挂简历不理了
点赞 评论 收藏
分享
Gaynes:查看图片
点赞 评论 收藏
分享
在瑞幸干两年,奥特曼都得闪灯
不知名的牛友:奥特曼每天只上3分钟班
点赞 评论 收藏
分享
评论
1
1
分享

创作者周榜

更多
牛客网
牛客网在线编程
牛客网题解
牛客企业服务