JavaScript实现的一个计算数字步数的算法分享


Posted in Javascript onDecember 06, 2014

这两天看了下某位大神的github,知道他对算法比较感兴趣,看了其中的一个计算数字的步数算法,感觉这个有点意思,所以就自己实现了一个。

算法描述与实现原理

给出一个整型数字,统计出有多少种走法可以到达目标,比如一个数字4,可以有下面几种走法

    [ 1, 3 ]

        [ 4 ]

    [ 1, 1, 2 ]

        [ 2, 2 ]

    [ 1, 1, 1, 1 ]

其实通过上面的组合可以得出下面的结论。

1.先列出所有项是1的组合
2.依次从左到右项为1的组合
3.递归上面的集合,找出项里1的索引,然后计算左起2项的值,结果递归此操作
4.排除1和2的情况

下面先提供三个工具函数:

// 计算数组内的值

function calculate(arg){

    return eval(arg.join('+'));

}
// 输出数组的值

function print(arg){

    for(var i = 0; i < arg.length; i++){

        console.log(arg[i]);

    }

}
// 检查是否是正反的走法

function hasRepeat(src, dist){

    if (dist.length != 2) return false;

    for(var i = 0, len = src.length; i < len ; i++){

        if(dist.length == src[i].length){

            if(dist[0] == src[i][1]){

                return true;

            }

        }

    }

    return false;

}

下面贴出算法的实现:

function countSteps(n){

    var counts = 0,i,j = 0;

    var result = [];

    var newresult = [];

    var source = [];

    var temparg = [];

    // 生成项全为1的数组

    for(i = 1; i <= n ; i++){

        source.push(1);

    }

    if(n > 2){

        for(j = 1; j < n - 1; j++){

            temparg.length = 0;

            if(j < n - 1){

                // 生成从左到右项为1递增的数组

                // 1.. 11.. 111..

                Array.prototype.push.apply(temparg, source.slice(0, j));

                temparg.push(calculate(source.slice(j,n)));

                result.push(temparg.slice(0));

                // 递归数组里的内容,直到项里没有1为止

                combine(temparg.slice(0));

            }

        }

    }

    // 组合包含1的数组项

    // 111->21->3

    function combine(arg){

        var linearg = [];

        for(var i = 0; i < arg.length; i++){

            if(arg[i] == 1){

                if(i ==0 || i == 1){

                    linearg.push(calculate(arg.slice(0,2)));

                    Array.prototype.push.apply(linearg, arg.slice(2, arg.length));

                    if(!hasRepeat(result, linearg)){

                        result.push(linearg);

                        combine(linearg.slice(0));

                    }

                    return;

                }

            }

        }

    }

    //为2的时候比1要多一项

    if(n == 2){

        result.push([2]);

    }

    // 添加全为1的情况

    result.push(source);

    // 输出所有步

    print(result);

    console.log('总共有:' + result.length + '种走法');

}
// 运行

countSteps(4);
// 输出下面内容

/*

    [ 1, 3 ]

    [ 4 ]

    [ 1, 1, 2 ]

    [ 2, 2 ]

    [ 1, 1, 1, 1 ]

    总共有:5种走

*/

总结

这个算法其实可以应用到某类游戏中去,当两个物体之前的距离一定的话,对所有的可能进行业务处理,当然也可以应用到别的地方,虽然大部分前端工程师对算法的实践比较少,不过它还是有存在的价值的,很多UI细节方面其实都运用了算法,以后有空还会贴更多关于算法相关的文章,欢迎大家多提些宝贵意见.

Javascript 相关文章推荐
超简单的jquery的AJAX用法
May 10 Javascript
JavaScript中双叹号(!!)作用示例介绍
Apr 10 Javascript
控制文字内容的显示与隐藏示例
Jun 11 Javascript
页面内容排序插件jSort使用方法
Oct 10 Javascript
js实现瀑布流的三种方式比较
Jun 28 Javascript
详解从Node.js的child_process模块来学习父子进程之间的通信
Mar 27 Javascript
详解Vue中使用v-for语句抛出错误的解决方案
May 04 Javascript
解决option标签selected=&quot;selected&quot;属性失效的问题
Nov 06 Javascript
详解Angular-ui-BootStrap组件的解释以及使用
Jul 13 Javascript
微信小程序实现跑马灯效果
Oct 21 Javascript
详解vue项目中使用token的身份验证的简单实践
Mar 08 Javascript
小程序实现背景音乐播放和暂停
Jun 19 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
node.js中实现同步操作的3种实现方法
Dec 05 #Javascript
You might like
PHP URL路由类实例
2013/11/12 PHP
php实现的debug log日志操作类实例
2016/07/12 PHP
php 函数使用可变数量的参数方法
2017/05/02 PHP
PHP简单实现模拟登陆功能示例
2017/09/15 PHP
PHP判断是否是微信打开还是浏览器打开的方法
2019/02/27 PHP
javascript sudoku 数独智力游戏生成代码
2010/03/27 Javascript
jQuery)扩展jQuery系列之一 模拟alert,confirm(一)
2010/12/04 Javascript
js实现网页倒计时、网站已运行时间功能的代码3例
2014/04/14 Javascript
jQuery中change事件用法实例
2014/12/26 Javascript
在Node.js应用中读写Redis数据库的简单方法
2015/06/30 Javascript
学习JavaScript鼠标响应事件
2015/12/25 Javascript
Bootstrap编写一个在当前网页弹出可关闭的对话框 非弹窗
2016/06/30 Javascript
javascript鼠标跟随运动3种效果(眼球效果,苹果菜单,方向跟随)
2016/10/27 Javascript
浅谈JS 数字和字符串之间相互转化的纠纷
2017/10/20 Javascript
使用Ajax和Jquery配合数据库实现下拉框的二级联动的示例
2018/01/25 jQuery
详解Webpack多环境代码打包的方法
2018/08/03 Javascript
详解angular2 控制视图的封装模式
2018/12/27 Javascript
js HTML DOM EventListener功能与用法实例分析
2020/04/27 Javascript
一个检测OpenSSL心脏出血漏洞的Python脚本分享
2014/04/10 Python
用Python徒手撸一个股票回测框架搭建【推荐】
2019/08/05 Python
Python调用Windows命令打印文件
2020/02/07 Python
Python函数基本使用原理详解
2020/03/19 Python
Python退出时强制运行一段代码的实现方法
2020/04/29 Python
兰蔻加拿大官方网站:Lancome加拿大
2016/08/05 全球购物
C#面试常见问题
2013/02/25 面试题
优秀研究生自我鉴定
2013/12/04 职场文书
旅游管理专业个人求职信范文
2013/12/24 职场文书
汽车专业人才自我鉴定范文
2013/12/29 职场文书
查环查孕证明
2014/01/10 职场文书
家长对老师的评语
2014/04/18 职场文书
法制宣传口号
2014/06/16 职场文书
文明好少年事迹材料
2014/08/19 职场文书
2014年档案管理工作总结
2014/11/17 职场文书
超市督导岗位职责
2015/04/10 职场文书
2016年安全生产先进个人事迹材料
2016/02/29 职场文书
Python可视化学习之seaborn绘制矩阵图详解
2022/02/24 Python