如何不使用数组实现打印“杨辉三角形”?

一、杨辉三角形1.1 杨辉三角形的概念

杨辉三角,是二项式系数在三角形中的一种几何排列。在欧洲,这个表叫做帕斯卡三角形。帕斯卡(1623—-1662)是在1654年发现这一规律的,比杨辉要迟393年,比贾宪迟600年。杨辉三角是中国古代数学的杰出研究成果之一,它把二项式系数图形化,把组合数内在的一些代数性质直观地从图形中体现出来,是一种离散型的数与形的结合 。

我们先看一下杨辉三角形的打印结果:

如何不使用数组实现打印“杨辉三角形”?
1.2 杨辉三角形的性质

杨辉三角形有很多性质:

1). 每行端点与结尾的数为1.

2). 每个数等于它上方两数之和。

3). 每行数字左右对称,由1开始逐渐变大。

4). 第n行的数字有n项。

5). 前n行共[(1+n)n]/2 个数。

6).第n行的m个数可表示为 C(n-1,m-1),即为从n-1个不同元素中取m-1个元素的组合数。

7). 第n行的第m个数和第n-m+1个数相等 ,为组合数性质之一。

8). 每个数字等于上一行的左右两个数字之和。可用此性质写出整个杨辉三角。即第n+1行的第i个数等于第n行的第i-1个数和第i个数之和,这也是组合数的性质之一。即 C(n+1,i)=C(n,i)+C(n,i-1)

9). (a+b)^n^的展开式中的各项系数依次对应杨辉三角的第(n+1)行中的每一项。

10). 将第2n+1行第1个数,跟第2n+2行第3个数、第2n+3行第5个数……连成一线,这些数的和是第4n+1个斐波那契数;将第2n行第2个数(n>1),跟第2n-1行第4个数、第2n-2行第6个数……这些数之和是第4n-2个斐波那契数。

11). 将第n行的数字分别乘以10^(m-1)^,其中m为该数所在的列,再将各项相加的和为11^(n-1)^。 11^0^=1,

11^1^=1 * 10^0^ + 1 * 10^1^=11,

11^2^=1×10^0^+2×10^1^^+1×10^2^=121,

11^3^=1×10^0^+3×10^1^+3×10^2^+1×10^3^=1331,

11^4^=1×10^0^+4×10^1^10^2^+4×10^3+1×10^4=14641,

11^5^=1×10^0^+5×10^1^+10×10^2^+10×10^3^+5×10^4^+1×10^5^=161051。

12). 第n行数字的和为2^(n-1)^。1=2^(1-1)^,1+1=2^(2-1)^,1+2+1=2^(3-1)^,1+3+3+1=2^(4-1)^,1+4+6+4+1=2^(5-1)^,1+5+10+10+5+1=2^(6-1)^。

13). 斜线上数字的和等于其向左(从左上方到右下方的斜线)或向右拐弯(从右上方到左下方的斜线),拐角上的数字。1+1=2,1+1+1=3,1+1+1+1=4,1+2=3,1+2+3=6,1+2+3+4=10,1+3=4,1+3+6=10,1+4=5。

14). 将各行数字左对齐,其右上到左下对角线数字的和等于斐波那契数列的数字。1,1,1+1=2,2+1=3,1+3+1=5,3+4+1=8,1+6+5+1=13,4+10+6+1=21,1+10+15+7+1=34,5+20+21+8+1=55。

实现杨辉三角形的打印也有很多方式,今天我为大家介绍两种方式:

使用数组的方式:这也是网上比较常见的方式。需要使用数组,所以效率较低。不使用数组的方式:不需要使用数组,所以效率较高。二、使用数组的方式2.1 示意图

根据上面的性质,如果我们要打印一个11行的杨辉三角形,我们可以将整个排列看做是一个n行,0-n列的矩阵,再结合上面的性质8,我们将这个矩阵用一个二维数组来实现,如下图:

如何不使用数组实现打印“杨辉三角形”?
2.2 代码分步实现

2.2.1 根据示意图,我们先定义一个二维数组:

int n = 11;//要几行的数据 int[][] values = new int[n][];//定义n行,但暂时每行的列数先不定义

2.2.2 生成二维数组,根据杨辉三角形性质,n行的数字个数为n:

for(int i = 0;i < values.length ; i++){ values[i] = new int[i + 1];//行0有1列,行1有2列,….,行n有n+1列 }

2.2.3 填充二维数组:

for(int i = 0;i < values.length ; i++){ values[i] = new int[i + 1];//01列,行12列,….,行n有n+1for(int j = 0 ; j < values[i].length ; j++){ //根据性质1,每行的首尾都为:1 if(j == 0 || j == value[i].lenght – 1){ values[i][j] = 1; }else if(i > 1){//根据性质8,除首尾外的其它数字 = 上方数 + 上方左侧的数 values[i][j] = values[i – 1][j] + values[i – 1][j – 1]; } } }

2.2.4 完整代码:

public class YangHui { public static void main(String[] args) { yangHui(8); } private static void yangHui3(int n) { int[][] values = new int[n][];//定义n行,但暂时每行的列数先不定义 for(int i = 0;i < values.length ; i++){ values[i] = new int[i + 1];//行0有1列,行1有2列,….,行n有n+1列 for(int j = 0 ; j < values[i].length ; j++){ //根据性质1,每行的首尾都为:1 if(j == 0 || j == values[i].length – 1){ values[i][j] = 1; }else if(i > 1){//根据性质8,除首尾外的其它数字 = 上方数 + 上方左侧的数 values[i][j] = values[i – 1][j] + values[i – 1][j – 1]; } } } print(values); } private static void print(int[][] values) { for(int i = 0; i < values.length; i++) { for(int j = 0; j < values[i].length; j++) { System.out.printf(“%-4d”, values[i][j]); } System.out.println(); } } }

数组的方式比较好理解,但需要创建二维数组,效率较低,接下来我们看一下不需要数组的写法。

三、不使用数组的方式3.1 算法说明

根据性质6,第n行的m个数可表示为 C(n-1,m-1),即为从n-1个不同元素中取m-1个元素的组合数。

我们将其表示为C(i , j)的组合数,那么就有以下算法:

1、例如:i=3、j=2的位置上,值为C(3,2),即(3*2)/(1*2)=3/1 * 2/2 = 3 2、例如:i=5、j=3的位置上,值为C(5,3),即(5*4*3)/(1*2*3)= 5/1 * 4/2 * 3/3 = 5 * 2 * 1 = 10 3、例如:i=7、j=4的位置上,值为C(7,4),即(7*6*5*4)/(1*2*3*4) = 7/1 * 6/2 * 5/3 * 4/4 = 353.2 代码实现

根据上述算法,我们就可以很方便的写出以下代码:

private static void yangHui2(int n) { for(int i = 0; i < n; i++) {//行 for(int j = 0; j <= i; j++) {//列 //计算每列的值 int value = 1; for(int k = 0; k < j; k++) { value = value * (i-k) / (k+1); } System.out.printf(“%-4d”, value); } System.out.println(); } }

免责声明:文章内容来自互联网,本站仅作为分享,不对其真实性负责,如有侵权等情况,请与本站联系删除。
转载请注明出处:如何不使用数组实现打印“杨辉三角形”? https://www.dachanpin.com/a/cyfx/11839.html

(0)
上一篇 2023-05-12 03:49:15
一高级工程师发帖:好的代码不需要注释!网友吵翻了
下一篇 2023-05-12 03:50:20

相关推荐

  • “自主创业” 24岁成都小伙将3D打印机卖到欧美

      尽管只有24岁,而且是第一次创业,但个头不高的余晟睿对创业,显然有比同龄人更成熟的看法。“创业之初,应该专注细分品类的产品,在这一个品类做到第一,再通过这个缺口进行扩张。”余晟睿说,他的经验是不能在创业刚开始,就把战线拉得太长。   今年4月份,余晟睿的公司拿到了百万级的融资,但拿到投资人的钱后,让他倍感压力之大。“融资之前,我们团队想买什么就直接买买买…

    创业分享 2023-05-31
    94
  • 猩便利CEO吕广渝:创业公司的成功之道在于“势起人成”

    2018年1月14日,猩便利创始人兼CEO吕广渝受混沌大学之邀,开展了一场以《从上帝视角看公司运营》为主题的演讲。吕广渝创造性地提出了公司运营的四大框架,首次公开分享了自己在数十年职业生涯中所累积的宝贵经验,并向与会嘉宾阐释了猩便利背后的商业逻辑和未来的想象力。 经历了互联网的20年,移动互联网的10年,吕广渝可以说是互联网领域的一位集大成者。在这个过程中,…

    创业分享 2023-05-20
    180
  • 跟踪服务 创业基地

      ■城乡速递   新造镇   本报讯  (记者谭阳春  通讯员伍姗)近日,新造镇劳动和社会保障中心到新造镇同发创业基地开展跟踪服务工作,并向相关负责人详细讲解创业带动就业优惠政策。   当天,劳动中心工作人员向同发创业基地负责人详细讲解了创业基地相关补贴政策的内容、办理流程等事项,并派发了相关就业服务政策宣传资料。该…

    创业分享 2023-05-18
    146
  • 解放军报评论员文章:当干事创业者的坚强靠山

    ■解放军报评论员 “多一分关心就多一分温暖,多一分支持就多一分力量。”各级领导干部要带头履职尽责、带头担当作为、带头承担责任,身先士卒推动形成正确的事业观工作观政绩观。各级党组织要以高度的政治责任感和历史使命感,采取有效措施抓好《实施意见》学习贯彻,切实把党中央、中央军委和习主席对干部的关心激励落实落细。坚持严管和厚爱结合、激励和约束并重,既要严格执行政策法…

    2023-05-13
    170
  • 收盘:两市尾盘大幅跳水 创业板指跌近1%

      周四早盘,沪深两市低开而后震荡走高,沪指创近2个月新高,沪深指数略显分化,创业板指横盘震荡,上证50指数涨超1%,沪深300指数创17个月新高。午后上证50指数继续上攻,带领沪指冲高,创业板指则震荡下行,尾盘三大股指集体跳水,沪指几乎回吐全部涨幅,创业板指跌近1%。   中银国际证券认为,A股加入MSCI指数后,全球投资者会通过各种途径进入中国市场,他们…

    创业分享 2023-05-22
    121

发表回复

登录后才能评论

联系我们

在线咨询: QQ交谈

邮件:362039258@qq.com

工作时间:周一至周五,9:30-16:30,节假日休息