题解 | #求斐波那契(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).
全部评论

相关推荐

06-26 19:47
中南大学 Java
点赞 评论 收藏
分享
不愿透露姓名的神秘牛友
06-24 20:25
腾讯今年实习招了这么多人,后面秋招还会招人吗??想着秋招再战来着
牛客965593684号:腾讯好像2020年之后就是实习生招得多,应届生基本上不招,纯实习转正
点赞 评论 收藏
分享
舂锋:不能投什么岗都用一份简历,一般都是要看企业的岗位需求来写职业技能或者是项目经历,跟岗位相关的就写多一点。
点赞 评论 收藏
分享
05-05 21:45
已编辑
广州大学 Java
点赞 评论 收藏
分享
是每个人事都这样与找工作的人这样沟通吗?正常询问不可以吗
据说名字越长别人越关注你的昵称我觉得我要被关注了:excal 我还真不会
点赞 评论 收藏
分享
评论
1
1
分享

创作者周榜

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