日韩性视频-久久久蜜桃-www中文字幕-在线中文字幕av-亚洲欧美一区二区三区四区-撸久久-香蕉视频一区-久久无码精品丰满人妻-国产高潮av-激情福利社-日韩av网址大全-国产精品久久999-日本五十路在线-性欧美在线-久久99精品波多结衣一区-男女午夜免费视频-黑人极品ⅴideos精品欧美棵-人人妻人人澡人人爽精品欧美一区-日韩一区在线看-欧美a级在线免费观看

歡迎訪問 生活随笔!

生活随笔

當前位置: 首頁 > 编程资源 > 综合教程 >内容正文

综合教程

JavaScript斐波纳契数列非递归算法

發布時間:2023/11/21 综合教程 42 生活家
生活随笔 收集整理的這篇文章主要介紹了 JavaScript斐波纳契数列非递归算法 小編覺得挺不錯的,現在分享給大家,幫大家做個參考.

一般斐波納契數列采用遞歸或是數組緩存的方式,這里的方法不考慮重復計算斐波納契數列的情況。

fibonacci 數列定義,查看百度百科的解釋>>

n = 1,2 時,fib(n) = 1
n > 2 時,fib(n) = fib(n-2) + fib(n-1)

1、遞歸

<script type="text/javascript">
	function Fib(n) {
		return n < 2 ? n : (Fib(n - 1) + Fib(n - 2));
	}
</script>

2、數組緩存

<script type="text/javascript">
	var IterMemoFib = function() {
		var cache = [1, 1];
		return function(n) {
			if (n >= cache.length) {
				for (var i = cache.length; i < n; i++) {
					cache[i] = cache[i - 2] + cache[i - 1];
				}
			}
			return cache[n - 1];
		}
	}();
</script>

3、直接使用加法

<script type="text/javascript">
	function fib(n) {
		if (n < 2) {
			return 1;
		}
		var a = 1,
			b = 1;
		for (var i = 2; i < n - 1; i++) {
			b = a + b;
			a = b - a;
		}
		return a + b;
	}
</script>

對比:

如果只使用一次運算,第三種方法速度最快;

如果多次使用,第二種方法明顯優于其它兩種;

在n較大的情況下不推薦使用第一種;n為10*10000的時候遞歸就已經報內存溢出了

下面是在IE8下測試的結果(n為100W):

如果只需要計算一次,第三種方法應該是最優的,而且當n越大的時候,數組占有的內存空間也將越大。

完整代碼:

<!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01//EN" "http://www.w3.org/TR/html4/strict.dtd">
<html>
	<head>
		<title> new document </title>
		<meta name="generator" content="editplus" />
		<meta name="author" content="" />
		<meta name="keywords" content="" />
		<meta name="description" content="" />
		<meta http-equiv='content-type' content='text/html;charset=utf-8' />
	</head>

	<body>

		<script type="text/javascript">
			function Fib(n) {
				return n < 2 ? n : (Fib(n - 1) + Fib(n - 2));
			}

			var IterMemoFib = function() {
				var cache = [1, 1];
				return function(n) {
					if (n >= cache.length) {
						for (var i = cache.length; i < n; i++) {
							cache[i] = cache[i - 2] + cache[i - 1];
						}
					}
					return cache[n - 1];
				}
			}();

			function fib(n) {
				if (n < 2) {
					return 1;
				}
				var a = 1,
					b = 1;
				for (var i = 2; i < n - 1; i++) {
					b = a + b;
					a = b - a;
				}
				return a + b;
			}

			var num = 10000 * 100;

			function test(fn, n) {
				var date = +new Date();
				fn(n);
				return new Date().getTime() - date;
			}

			//document.write('第一種方法,運算時間:' + test(Fib, num) + '<br/>');
			document.write('第二種方法,運算時間:' + test(IterMemoFib, num) + '<br/>');
			document.write('第三種方法,運算時間:' + test(fib, num));

			document.write('<br/><br/><br/>');

			document.write('第二種方法,運算時間:' + test(IterMemoFib, num) + '<br/>');
			document.write('第三種方法,運算時間:' + test(fib, num));
		</script>

	</body>
</html>

轉自:http://www.cnblogs.com/meteoric_cry/archive/2010/11/29/1891241.html

總結

以上是生活随笔為你收集整理的JavaScript斐波纳契数列非递归算法的全部內容,希望文章能夠幫你解決所遇到的問題。

如果覺得生活随笔網站內容還不錯,歡迎將生活随笔推薦給好友。