Pascal三角形

简介: 作者:bakari   时间:2012.8.4   Pascal三角形又称杨辉三角形,是多项式系数的一种规律展示,最早是由我国数学家杨辉发现,比Pascal早200多年。 下面简单地总结一些其算法。

作者:bakari   时间:2012.8.4

 

Pascal三角形又称杨辉三角形,是多项式系数的一种规律展示,最早是由我国数学家杨辉发现,比Pascal早200多年。

下面简单地总结一些其算法。

一、数组计算法:

1、公式推导:

这个很简单,看图就知道

由图可得公式:a[ i ][ j ] = a[i - 1] [j - 1] + a[i - 1][ j ] 

2、代码展示:

 1 void YangHuiTriangleArray(int Row)                           
 2 {
 3     for (int i = 0;i < Row; i++)
 4     {
 5         for (int j = 0;j <= i; j++)
 6         {
 7             if (j == 0 || j == i)  //置1条件
 8                 a[i][j] = 1;
 9             else 
10                 a[i][j] = a[i - 1][j - 1] + a[i - 1][j];
11             cout<<a[i][j]<<" ";
12         }
13         cout<<endl;
14     }
15 }

二、递归法

这个是最好想到的,这一步的实现需要上一步作为铺垫。

废话不多说,直接来看代码

 1 long GetElement(int Row,int Col)
 2 {
 3     if (0 == Col || Row == Col)   //递归出口
 4         return 1;
 5     else 
 6         return GetElement(Row - 1,Col - 1) + GetElement(Row - 1,Col);
 7 }
 8 
 9 void YangHuiTriangleRecur(const long n)
10 {
11     for(int i = 0;i < n; i++)
12     {
13         for(int j = 0; j <= i; j++)
14             cout<<GetElement(i,j)<<" ";
15         cout<<endl;
16     }
17 }

三、数学推导法

本方法主要借助数学推导,比起前两种性能要好很多

令X10= 1 ;则

X20 = 1 , X21 = X20 * (2 - 1 + 1)/1 = 2 , X22 = X21 * (2 - 2 + 1)/2 = 1;

X30 = 1 , X31 = X30 * (3 - 1 + 1)/1 = 3 , X32 = X31 * (3 - 2 + 1)/2 = 3 , X33 = X32 * (3 - 3 + 1)/3 = 1;

.........

Xij = 1, Xij+1 = Xij * (i - j + 1)/j , ...... , Xii = 1;

 

大体就是这么个推导法,下面看代码:

 1 void YangHuiTriangle(int RowN)
 2 {
 3     for (int i = 0;i < RowN;i++)
 4     {
 5         for (int j = 0;j <= i;j++)
 6         {
 7             if (j == 0)        //第一个数前面要输出相应的空格
 8             {
 9                 for (int k = 1;k < RowN - i; k++)
10                     cout<<"  ";
11             }
12             else 
13                 cout<<" ";                          //数与数之间输出相应空格  
14             printf("%3d",ComputeNextInteger(i,j));  //输出下一个数
15         }
16         cout<<endl;
17     }
18 }
19 
20 int ComputeNextInteger(int iRow ,int iRowIndex)
21 {
22     long p = 1;
23     for (int i = 1;i <= iRowIndex; i++)    
24         p = p * (iRow - i + 1)/i;            //根据公式计算每一个数;
25     return p;
26 }

见图:

 

OK!希望多多烧香!  

目录
相关文章
|
存储 JavaScript 前端开发
DOM 规范 —— MutationObserver 接口
DOM 规范 —— MutationObserver 接口
377 0
|
8月前
|
Shell 开发者 Docker
Python文件打包:一站式指南
本文深入探讨Python文件打包的各种方法,从基础的zip和tar工具到高级的setuptools、PyInstaller、cx_Freeze等,涵盖Docker镜像、虚拟环境及自包含可执行文件的打包方式。通过示例代码与详细解析,帮助开发者根据项目需求选择合适的打包方案,提升代码分发与部署效率。内容全面,适合各水平读者学习参考。
619 7
|
存储 搜索推荐 JavaScript
【毕业设计之java系列】基于springboot学生社团信息管理系统
【毕业设计之java系列】基于springboot学生社团信息管理系统
830 0
|
JavaScript 前端开发 Java
Github 上 8 个很棒的 Vue 项目
Github 上 8 个很棒的 Vue 项目
640 0
|
人工智能 Linux Docker
一文详解几种常见本地大模型个人知识库工具部署、微调及对比选型(1)
近年来,大模型在AI领域崭露头角,成为技术创新的重要驱动力。从AlphaGo的胜利到GPT系列的推出,大模型展现出了强大的语言生成、理解和多任务处理能力,预示着智能化转型的新阶段。然而,要将大模型的潜力转化为实际生产力,需要克服理论到实践的鸿沟,实现从实验室到现实世界的落地应用。阿里云去年在云栖大会上发布了一系列基于通义大模型的创新应用,标志着大模型技术开始走向大规模商业化和产业化。这些应用展示了大模型在交通、电力、金融、政务、教育等多个行业的广阔应用前景,并揭示了构建具有行业特色的“行业大模型”这一趋势,大模型知识库概念随之诞生。
156470 30
|
数据可视化 测试技术
9个时间序列交叉验证方法的介绍和对比
在本文中,我们收集了时间序列的常用的9种交叉验证方法。这些包括样本外验证(holdout)或流行的K-fold交叉验证的几个扩展。
2145 0
9个时间序列交叉验证方法的介绍和对比
|
机器学习/深度学习 自然语言处理 算法
深度学习的奥秘:探索神经网络的核心机制
在这篇文章中,我们将深入浅出地探讨深度学习背后的科学原理和实际应用。通过简化的语言和生动的比喻,我们将揭示神经网络如何模仿人脑处理信息的方式,以及它们如何在各种领域内实现惊人的成就。无论你是技术新手还是资深专家,这篇文章都将为你提供新的视角和深刻的见解。
|
运维 测试技术
团队交付质量如何评估
团队交付质量如何评估
570 0
团队交付质量如何评估
|
机器学习/深度学习 算法 搜索推荐
Stacking:解决机器学习进行多模型组合的实用工具
在机器学习领域,算法的选择和参数的调整一直是让人头痛的难题。虽然有很多算法可以使用,但没有一种算法是万能的。随着技术的不断发展,出现了一些新的技术可以在算法选择和调整参数方面提供一些帮助。其中最流行的技术之一是Stacking。 Stacking是一种用于增强机器学习模型性能的技术。该技术通过结合不同算法的预测结果来生成最终的预测结果。这种方法能够帮助解决许多机器学习问题,特别是当单一算法不足以解决问题时。
|
数据采集 存储 搜索推荐
分析新闻评论数据并进行情绪识别
爬取新闻评论数据并进行情绪识别的目的是为了从网页中抓取用户对新闻事件或话题的评价内容,并从中识别和提取用户的情绪或态度,如积极、消极、中立等。爬取新闻评论数据并进行情绪识别有以下几个优势: 1)可以了解用户对新闻事件或话题的看法和感受,以及影响他们情绪的因素; 2)可以分析用户的情绪变化和趋势,以及与新闻事件或话题的相关性和影响力; 3)可以根据用户的情绪进行个性化的推荐或服务,如提供正能量的内容、提供帮助或建议等;
448 1

热门文章

最新文章