课程表

CoffeeScript 语法

CoffeeScript 类和对象

CoffeeScript 字符串

CoffeeScript 数组

CoffeeScript 日期和时间

CoffeeScript 数学

CoffeeScript 方法

CoffeeScript 元编程

CoffeeScript jQuery

CoffeeScript 正则表达式

CoffeeScript 网络

CoffeeScript 设计模式

CoffeeScript 数据库

CoffeeScript 测试

工具箱
速查手册

更快的斐波那契数列算法

当前位置:免费教程 » JS/JS库/框架 » CoffeeScript

问题

你想计算出 斐波那契数列中的数值 N ,但需迅速地算出结果。

解决方案

下面的方案(仍有需改进的地方)最初在 Robin Houston 的博客上被提出来。

这里给出一些关于该算法和改进方法的链接:

以下的代码来源于:https://gist.github.com/1032685

  1. ###
  2. Author: Jason Giedymin <jasong _a_t_ apache -dot- org>
  3. http://www.jasongiedymin.com
  4. https://github.com/JasonGiedymin
  5. CoffeeScript Javascript 的快速 Fibonacci 代码是基于 Robin Houston 博客里的 python 代码。
  6. 见下面的链接。
  7. 我要介绍一下 NewtonianBurnikel / Ziegle Binet 关于大数目框架算法的实现。
  8. Todo:
  9. - https://github.com/substack/node-bigint
  10. - BZ and Newton mods.
  11. - Timing
  12. ###
  13. MAXIMUM_JS_FIB_N = 1476
  14. fib_bits = (n) ->
  15. #代表一个作为二进制数字阵列的整数
  16. bits = []
  17. while n > 0
  18. [n, bit] = divmodBasic n, 2
  19. bits.push bit
  20. bits.reverse()
  21. return bits
  22. fibFast = (n) ->
  23. #快速 Fibonacci
  24. if n < 0
  25. console.log "Choose an number >= 0"
  26. return
  27. [a, b, c] = [1, 0, 1]
  28. for bit in fib_bits n
  29. if bit
  30. [a, b] = [(a+c)*b, b*b + c*c]
  31. else
  32. [a, b] = [a*a + b*b, (a+c)*b]
  33. c = a + b
  34. return b
  35. divmodNewton = (x, y) ->
  36. throw new Error "Method not yet implemented yet."
  37. divmodBZ = () ->
  38. throw new Error "Method not yet implemented yet."
  39. divmodBasic = (x, y) ->
  40. ###
  41. 这里并没有什么特别的。如果可能的话,也许以后的版本将是Newtonian 或者 Burnikel / Ziegler 的。
  42. ###
  43. return [(q = Math.floor x/y), (r = if x < y then x else x % y)]
  44. start = (new Date).getTime();
  45. calc_value = fibFast(MAXIMUM_JS_FIB_N)
  46. diff = (new Date).getTime() - start;
  47. console.log "[#{calc_value}] took #{diff} ms."
转载本站内容时,请务必注明来自W3xue,违者必究。
 友情链接:直通硅谷  点职佳  北美留学生论坛

本站QQ群:前端 618073944 | Java 606181507 | Python 626812652 | C/C++ 612253063 | 微信 634508462 | 苹果 692586424 | C#/.net 182808419 | PHP 305140648 | 运维 608723728

W3xue 的所有内容仅供测试,对任何法律问题及风险不承担任何责任。通过使用本站内容随之而来的风险与本站无关。
关于我们  |  意见建议  |  捐助我们  |  报错有奖  |  广告合作、友情链接(目前9元/月)请联系QQ:27243702 沸活量
皖ICP备17017327号-2 皖公网安备34020702000426号