一次面试中,面试官要求用三种不同的Javascript方法进行一个数字数组的求和,当时思来想去只想到了使用循环这一种笨方法,因此面试比较失败,在这里总结了六种Javascript进行数组求和的方法,以便参考,也好让大家重温一下Javascript基础知识

需求 ,任意一个不知长度的纯数字数组(可以整数、小数或负数),求数组所有元素之和

方法一当然是先想到使用最笨的暴力方法,循环求和法:(其实并不笨,毕竟循环是所有编程语言的一个重要方法,使用它并不丢脸)

二话不说 上代码

var arr = [1,3,4,5,2,3,4,33,3,2,33,33,55,66,77,222,55,3];

var len= arr.length;
var sum = 0;
for(var i=0;i<len;i++){
sum += arr[i];
}
console.log(sum); //输出604

总结一下,可以提取出一个建立在Array对象上的通用方法:

第一种方法:(思路:使用for循环)

 Array.prototype.sum0 = function(){
var len= this.length;
var sum = 0;
for(var i=0;i<len;i++){
sum += this[i];
};
return sum;
}; var arr = [1,2,3,4,5]; console.log(arr.sum0); //

那么废话不多说:几种方法依次如下

第二种方法:  思路 (使用while循环,使用do...while思路是类似的)

Array.prototype.sum1 = function(){
var sum = 0;
var i = 0;
while(arr[i]){
sum += this[i];
i++;
};
return sum;
}; var arr = [1,2,3,4,5]; arr.sum1(); //

第三种方法:  思路 (使用递归调用)
那么 : 普通的递归方法如下

Array.prototype.sum2_0 = function(){
var arr = this;
var sum = function(n){
if(n<1){
return NaN
}else {
return (n==1)? arr[0] : arr[n-1]+sum(n-1)
}
};
return sum(this.length);
} var arr = [1,2,4,5,6]; arr.sum2_0(); //

在Javascript中,普通递归调用是一种不推荐的方法,当数组中数目较多时,执行非常慢,基于斐波那契数列的启发(斐波那契数列算法见文章最后),总结出一种加强版递归方法如下:

Array.prototype.sum2 = function(){
var arr=this;
var sum = (function(){
var memory = [];
return function(n){
if(memory[n] != undefined){
return memory[n]
}else{
if(n<1){
return NaN
}else{
return memory[n] = (n==1)? arr[0] : arr[n-1]+sum(n-1)
}
}
}
})();
return sum(this.length);
}; var arr=[1,2,3,4,5]; arr.sum2(); //

第四种方法:  思路 (使用ES5中Array对象新增的方法reduce)

Array.prototype.sum3 = function(){
return this.reduce(function (a, b){
return a + b;
})
}; var arr = [1,2,3,4,5]; arr.sum3(); //

第五种方法:  思路 (使用ES5中Array对象新增的方法forEach)

Array.prototype.sum4 = function(){
var sum = 0;
this.forEach(function(item){
sum+=item;
});
return sum;
}; var arr = [1,2,3,4,5]; arr.sum4(); //

第六种方法:  思路 (使用Javascript中的特殊方法eval())

Array.prototype.sum5 = function(){
var num = function(item){
return (typeof item == "number")
}; //加了一句数组元素是否为数字的判断,其实上面的每一个例子都需要加判断,只是我们省略了,在最后要重申这一点
if(this.every(num)){
return eval(this.join("+"));
}else {
return NaN
}
}; var arr = [1,2,3,4,5]; arr.sum5(); //

文章的最后就要介绍一下给我启发的斐波那契数列算法:

普通的斐波那契数列公式:(普通递归调用)

function fibonacci(n){
if(n==0||n==1){
return 1
}else {
return fibonacci(n-2)+fibonacci(n-1)
}
}; console.log(fibonacci(10)); //输出55 console.log(fibonacci(100)); //浏览器卡住,几乎没有反应,

加强版的斐波那契数列公式:使用了memoization的方法:

memoization方案在《JavaScript模式》和《JavaScript设计模式》都有提到。memoization是一种将函数执行结果用变量缓存起来的方法。当函数进行计算之前,先看缓存对象中是否有次计算结果,如果有,就直接从缓存对象中获取结果;如果没有,就进行计算,并将结果保存到缓存对象中。

var Fibonacci = (function(){
var memory = [];
return function(n){
if(memory[n] != undefined){
return memory[n]
}else {
return memory[n] = (n==0|| n ==1)? n : Fibonacci(n-2)+Fibonacci(n-1)
}
}
})(); console.log(Fibonacci(100)); // 输出 354224848179262000000 (几乎瞬间完成)

Javascript数组求和的方法总结 以及由斐波那契数列得到的启发的更多相关文章

  1. 方法输出C++输出斐波那契数列的几种方法

    PS:今天上午,非常郁闷,有很多简单基础的问题搞得我有些迷茫,哎,代码几天不写就忘.目前又不当COO,还是得用心记代码哦! 定义: 斐波那契数列指的是这样一个数列:0, 1, 1, 2, 3, 5, ...

  2. {每日一题}:四种方法实现打印feibo斐波那契数列

    刚开始学Python的时候,记得经常遇到打印斐波那契数列了,今天玩玩使用四种办法打印出斐波那契数列 方法一:使用普通函数 def feibo(n): """ 打印斐波那契 ...

  3. 使用并行的方法计算斐波那契数列 (Fibonacci)

    更新:我的同事Terry告诉我有一种矩阵运算的方式计算斐波那契数列,更适于并行.他还提供了利用TBB的parallel_reduce模板计算斐波那契数列的代码(在TBB示例代码的基础上修改得来,比原始 ...

  4. javascript . 03 函数定义、函数参数(形参、实参)、函数的返回值、冒泡函数、函数的加载、局部变量与全局变量、隐式全局变量、JS预解析、是否是质数、斐波那契数列

    1.1 知识点 函数:就是可以重复执行的代码块 2.  组成:参数,功能,返回值 为什么要用函数,因为一部分代码使用次数会很多,所以封装起来, 需要的时候调用 函数不调用,自己不会执行 同名函数会覆盖 ...

  5. js算法集合(二) javascript实现斐波那契数列 (兔子数列)

    js算法集合(二)  斐波那契数列 ★ 上一次我跟大家分享一下做水仙花数的算法的思路,并对其扩展到自幂数的算法,这次,我们来对斐波那契数列进行研究,来加深对循环的理解.     Javascript实 ...

  6. javascript 实现斐波那契数列的不同姿势

    快过年了,公司人基本上都走光了,只有共和国最优秀的人才,各部门最重要的岗位才会坚守在各自的转椅上,毕竟每个人的能力有限,与其让他们继续工作,不如放他们回家过年.这觉悟很高,这领悟很痛~    闲着没事 ...

  7. 斐波那契数列-java编程:三种方法实现斐波那契数列

    题目要求:编写程序在控制台输出斐波那契数列前20项,每输出5个数换行 斐波那契数列指的是这样一个数列:1, 1, 2, 3, 5, 8, 13, 21, 34, 55, 89, 144, … 这个数列 ...

  8. 斐波拉契数列(用JavaScript和Python实现)

    1.用JavaScript 判断斐波拉契数列第n个数是多少 //需求:封装一个函数,求斐波那契数列的第n项 //斐波拉契数列 var n=parseInt(prompt("输入你想知道的斐波 ...

  9. JS高级. 06 缓存、分析解决递归斐波那契数列、jQuery缓存、沙箱、函数的四种调用方式、call和apply修改函数调用方法

    缓存 cache 作用就是将一些常用的数据存储起来 提升性能 cdn //-----------------分析解决递归斐波那契数列<script> //定义一个缓存数组,存储已经计算出来 ...

随机推荐

  1. Python 实现的随机森林

    随机森林是一个高度灵活的机器学习方法,拥有广泛的应用前景,从市场营销到医疗保健保险. 既可以用来做市场营销模拟的建模,统计客户来源,保留和流失.也可用来预测疾病的风险和病患者的易感性. 随机森林是一个 ...

  2. 五年.net程序员转型Java之路

    大学毕业后笔者进入一家外企,做企业CRM系统开发,那时候开发效率最高的高级程序语言,毫无疑问是C#.恰逢公司也在扩张,招聘了不少.net程序员,笔者作为应届生,也乐呵呵的加入到.net程序员行列中. ...

  3. HIVE---基于Hadoop的数据仓库工具讲解

    Hadoop: Hadoop是一个由Apache基金会所开发的分布式系统基础架构.用来开发分布式程序.充分利用集群的威力进行高速运算和存储.Hadoop实现了一个分布式文件系统(Hadoop Dist ...

  4. JS双击div编辑文本内容

    HTML代码: <div class="album"> <div class="image"><a href="java ...

  5. RobotFramework自动化测试框架-移动手机自动化测试Click A Point关键字的使用

    Click A Point关键字用来模拟点击APP界面上的一个点,该关键字接收两个三个参数[ x=0 | y=0 | duration=100 ],x和y代表的是点的坐标位置,duration代表的是 ...

  6. #云栖大会# 移动安全专场——APP渠道推广作弊攻防那些事儿(演讲速记)

    导语: 如今,移动互联网浪潮进入白热化竞争态势,APP渠道传播成为很多企业常用的推广方式,APP推广费用也在水涨船高,从PC时代的一个装机0.5元到1元不等,到移动互联网时代的5元,甚至几十元,但为什 ...

  7. 吐槽CSDN--想钱想疯了--推荐文章里面广告博文去不掉

    CSDN广告手段高,广告博文删不掉! 如图所示,我自己的博客文章下面有个相关文章推荐,这是csdn新出的信息流式内容呈现方式,也没什么太大问题.只是,你在里面放广告"羊毛衫,弹力裤" ...

  8. 【特效】体验很好的导航hover效果移出恢复当前位置

    很常见的一种导航的hover效果,鼠标放上后除了正常的hover,在移出整个导航后,会恢复当前栏目的特殊样式,分别有横向和纵向的导航.代码也比较简单,设置一个当前栏目的class,用index()找到 ...

  9. 使用Xshell5连接虚拟机VMware中安装的CentOS7系统

    使用Xshell5连接VMware中安装的CentOS7系统 准备材料 Xshell 下载地址 VMware Workstation 12 Pro 下载地址 CentOS 7 64位系统 下载地址 安 ...

  10. java选择结构

    /**选择结构*/ public class Demo06{ public static void main(String []args){ // if...else...型 String name ...