JS实现的杨辉三角【帕斯卡三角形】算法示例


Posted in Javascript onFebruary 26, 2019

本文实例讲述了JS实现的杨辉三角【帕斯卡三角形】算法。分享给大家供大家参考,具体如下:

杨辉三角,是二项式系数在三角形中的一种几何排列,在中国南宋数学家杨辉1261年所著的《详解九章算法》一书中出现。 在欧洲,帕斯卡(1623-1662)在1654年发现这一规律,所以这个表又叫做帕斯卡三角形。 帕斯卡的发现比杨辉要迟393年,比贾宪迟600年。

JS实现的杨辉三角【帕斯卡三角形】算法示例

题目: 给定非负整数numRows,生成Pascal三角形的第一个numRows。在Pascal的三角形中,每个数字是它上面两个数字的总和。

输入: 5

输出:

[
     [1],
    [1,1],
   [1,2,1],
  [1,3,3,1],
 [1,4,6,4,1]
]

JS代码如下:

<script>
var generate = function(numRows) {
  if (numRows) {
    var result = [[1]];
    for(var i = 1;i < numRows;i++) {
      result[i] = [];
      for(var j = 0; j < i + 1;j++) {
        result[i][j] = (result[i - 1][j] || 0) + (result[i - 1][j - 1] || 0);
      }
    }
    return result;
  }else {
    return [];
  }
};
console.log(generate(1000));
</script>

使用在线HTML/CSS/JavaScript代码运行工具:http://tools.3water.com/code/HtmlJsRun测试上述代码,可得如下运行结果:

JS实现的杨辉三角【帕斯卡三角形】算法示例

由于数据比较多,这里仅展示一部分运算结果,感兴趣的朋友可以自己动手测试一下,看看运行效果。

希望本文所述对大家JavaScript程序设计有所帮助。

Javascript 相关文章推荐
TFDN图片播放器 不错自动播放
Oct 03 Javascript
javascript预览上传图片发现的问题的解决方法
Nov 25 Javascript
offsetHeight在OnLoad中获取为0的现象
Jul 22 Javascript
Node.js实现批量去除BOM文件头
Dec 20 Javascript
js+HTML5实现canvas多种颜色渐变效果的方法
Jun 05 Javascript
javascript常用函数(1)
Nov 04 Javascript
41个Web开发者必须收藏的JavaScript实用技巧
Jul 22 Javascript
JavaScript中定义对象原型的两种使用方法
Dec 15 Javascript
微信小程序实现页面跳转传值的方法
Oct 12 Javascript
微信小程序使用toast消息对话框提示用户忘记输入用户名或密码功能【附源码下载】
Dec 09 Javascript
react-router4按需加载(踩坑填坑)
Jan 06 Javascript
浅谈Vue SSR中的Bundle的具有使用
Nov 21 Javascript
create-react-app使用antd按需加载的样式无效问题的解决
Feb 26 #Javascript
JS实现电话号码的字母组合算法示例
Feb 26 #Javascript
JS实现的合并两个有序链表算法示例
Feb 25 #Javascript
JS实现判断有效的数独算法示例
Feb 25 #Javascript
js实现通过开始结束控制的计时器
Feb 25 #Javascript
js实现倒计时器自定义时间和暂停
Feb 25 #Javascript
JS module的导出和导入的实现代码
Feb 25 #Javascript
You might like
PHP技术开发微信公众平台
2015/07/22 PHP
php实现简单爬虫的开发
2016/03/28 PHP
PHP strip_tags保留多个HTML标签的方法
2016/05/22 PHP
php+flash+jQuery多图片上传源码分享
2020/07/27 PHP
thinkPHP5 tablib标签库自定义方法详解
2017/05/10 PHP
PHP实现的策略模式示例
2019/03/20 PHP
validator验证控件使用代码
2010/11/23 Javascript
EasyUI的treegrid组件动态加载数据问题的解决办法
2011/12/11 Javascript
jquery Moblie入门—hello world的示例代码学习
2013/01/08 Javascript
提高NodeJS中SSL服务的性能
2014/07/15 NodeJs
jQuery实现的多屏图像图层切换效果实例
2015/05/07 Javascript
利用JS屏蔽页面中的Enter按键提交表单的方法
2016/11/25 Javascript
JQuery 动态生成Table表格实例代码
2016/12/02 Javascript
Vue.js系列之项目结构说明(2)
2017/01/03 Javascript
jQuery简易时光轴实现方法示例
2017/03/13 Javascript
Vue2.0 UI框架ElementUI使用方法详解
2017/04/14 Javascript
JS作用域链详解
2017/06/26 Javascript
浅谈AngularJs 双向绑定原理(数据绑定机制)
2017/12/07 Javascript
JavaScript实现表单注册、表单验证、运算符功能
2018/10/15 Javascript
详解CommonJS和ES6模块循环加载处理的区别
2018/12/26 Javascript
Vue中this.$nextTick的作用及用法
2020/02/04 Javascript
Python编程语言的35个与众不同之处(语言特征和使用技巧)
2014/07/07 Python
python颜色随机生成器的实例代码
2020/01/10 Python
python GUI库图形界面开发之PyQt5控件数据拖曳Drag与Drop详细使用方法与实例
2020/02/27 Python
如何解决flask修改静态资源后缓存文件不能及时更改问题
2020/08/02 Python
Python configparser模块应用过程解析
2020/08/14 Python
python 使用建议与技巧分享(四)
2020/08/18 Python
html5中canvas学习笔记2-判断浏览器是否支持canvas
2013/01/06 HTML / CSS
幼儿园门卫制度
2014/01/29 职场文书
关心下一代工作先进事迹
2014/08/15 职场文书
2014年施工员工作总结
2014/11/18 职场文书
项目投资意向书范本
2015/05/09 职场文书
2015年三年级班主任工作总结
2015/05/21 职场文书
美德少年主要事迹材料
2015/11/04 职场文书
导游词之苏州寒山寺
2019/12/05 职场文书
django如何自定义manage.py管理命令
2021/04/27 Python