JavaScript实现twitter puddles算法实例


Posted in Javascript onDecember 06, 2014

今天发现了一个挺好玩的算法题,下面是它的算法描述,源自twitter的一道面试题。

twitter puddles 算法描述

先看一副图

JavaScript实现twitter puddles算法实例

上图里的数字是根据一个数组内容来描述的,最后会根据每个数字的大小来模拟一道墙的高度,最后生成一面墙,问你,当下雨的时候,这面墙可以装多少水,以1为计数单位。

下面是装完水之后的一面墙的样子

JavaScript实现twitter puddles算法实例

看完上面上幅图,感觉是不是很好玩,确实,下面来简单的分析下它的算法实现

其实这个原理比较简单,总共有下面几个要点:

1.最左边和最右边肯定不能装水
2.装水的高度依赖自身左右两侧内两个最大值其中的最小值

下面我们用js来简单的实现它:

/**

*  计算以数组项为高度的墙能装多少水

*  数组例子 [2,5,1,2,3,4,7,7,6,9]

**/

function getWaterCounts(arg){

    var i = 0,

        j = 0,

        count = 0;

    // 第一项和最后一项都得排除

    for(i = 1; i < arg.length - 1; i++){

        var left = Math.max.apply(null, arg.slice(0, i + 1));

        var right = Math.max.apply(null, arg.slice(i, arg.length));

        var min = left >= right ? right : left;

        // 以左右两边最大值内小的为准

        // 假如当前值大于或者等于这个值什么都不做

        if(arg[i] < min){

            count += min - arg[i];

        }

    }

    console.log(count);

}

getWaterCounts([2,5,1,2,3,4,7,7,6,9]); // 11

总结

嘿嘿,实现是不是挺简单的,其实只要你愿意思考,用js可以实现很多好玩的东西.

Javascript 相关文章推荐
jquery插件制作简单示例说明
Feb 03 Javascript
JQuery拖拽元素改变大小尺寸实现代码
Dec 10 Javascript
js计算字符串长度包含的中文是utf8格式
Oct 15 Javascript
jQuery常用数据处理方法小结
Feb 20 Javascript
解析javascript中鼠标滚轮事件
May 26 Javascript
javascript中Number的方法小结
Nov 21 Javascript
React-Native之定时器Timer的实现代码
Oct 04 Javascript
vue-scroller记录滚动位置的示例代码
Jan 17 Javascript
js 图片转base64的方式(两种)
Apr 24 Javascript
JavaScript实现创建自定义对象的常用方式总结
Jul 09 Javascript
小程序实现单选多选功能
Nov 04 Javascript
如何解决jQuery 和其他JS库的冲突
Jun 22 jQuery
JavaScript实现的一个计算数字步数的算法分享
Dec 06 #Javascript
angularjs中的e2e测试实例
Dec 06 #Javascript
angularjs中的单元测试实例
Dec 06 #Javascript
angularjs指令中的compile与link函数详解
Dec 06 #Javascript
angularjs的一些优化小技巧
Dec 06 #Javascript
JavaScript开发人员的10个关键习惯小结
Dec 05 #Javascript
node.js中RPC(远程过程调用)的实现原理介绍
Dec 05 #Javascript
You might like
phpmyadmin显示utf8_general_ci中文乱码的问题终级篇
2013/04/08 PHP
深入for,while,foreach遍历时间比较的详解
2013/06/08 PHP
php实现向javascript传递数组的方法
2015/07/27 PHP
php实现XML和数组的相互转化功能示例
2017/02/08 PHP
php爬取天猫和淘宝商品数据
2018/02/23 PHP
php 实现银联商务H5支付的示例代码
2019/10/12 PHP
AeroWindow 基于JQuery的弹出窗口插件
2011/06/27 Javascript
深入理解JavaScript系列(7) S.O.L.I.D五大原则之开闭原则OCP
2012/01/15 Javascript
js使用removeChild方法动态删除div元素
2014/08/01 Javascript
javascript获取四位数字或者字母的随机数
2015/01/09 Javascript
JS实现状态栏跑马灯文字效果代码
2015/10/24 Javascript
快速学习jQuery插件 Cookie插件使用方法
2015/12/01 Javascript
js+ajax实现获取文件大小的方法
2015/12/08 Javascript
浅谈JS继承_借用构造函数 &amp; 组合式继承
2016/08/16 Javascript
简单实现jQuery轮播效果
2017/08/18 jQuery
jquery动态添加以及遍历option并获取特定样式名称的option方法
2018/01/29 jQuery
js将键值对字符串转为json字符串的方法
2018/03/30 Javascript
vue 中swiper的使用教程
2018/05/22 Javascript
vue中通过使用$attrs实现组件之间的数据传递功能
2019/09/01 Javascript
vue打包npm run build时候界面报错的解决
2020/08/13 Javascript
[01:16:28]DOTA2-DPC中国联赛 正赛 iG vs Magma BO3 第二场 2月23日
2021/03/11 DOTA
Python解析网页源代码中的115网盘链接实例
2014/09/30 Python
python通过apply使用元祖和列表调用函数实例
2015/05/26 Python
详解Python在七牛云平台的应用(一)
2017/12/05 Python
python 提取tuple类型值中json格式的key值方法
2018/12/31 Python
Python3几个常见问题的处理方法
2019/02/26 Python
网易微博Web App用HTML5开发的过程介绍
2012/06/13 HTML / CSS
Wilson体育用品官网:美国著名运动器材品牌
2019/05/12 全球购物
什么是设计模式
2012/06/17 面试题
中软国际Java程序员笔试题
2014/07/19 面试题
班班通校本培训方案
2014/03/12 职场文书
2014年教师工作总结
2014/11/10 职场文书
教师节倡议书2015
2015/04/27 职场文书
2016教师学习教育法心得体会
2016/01/19 职场文书
如何制定一份可行的计划!
2019/06/21 职场文书
JS高级程序设计之class继承重点详解
2022/07/07 Javascript