杨辉三角

package home;


import java.util.Scanner;


public class YangHui {
public static void main(String args[]) {

//键盘输入杨辉三角的行数
   Scanner input = new Scanner(System.in);
   System.out.print("请输入杨辉三角的行数:");
    int row=input.nextInt();
     
        //int x=10;//输入几层是几层  
        int num[][] = new int[row][row];//这个数组有几层  
        for(int m=0;m<row;m++)//主要是对数组进行赋值  
        {  
            for(int n=0;n<=m;n++)//每一层的个数都是小于等于层数的,m代表层数,n代表每一层的个数
            {  
                if(n==0||m==n)//每一层的开头都是1,m==n的时候也是1,必须要这个,凡事都得有个开头   
                {  
                    num[m][n]=1;  
                }  
                else  
                    num[m][n]=num[m-1][n-1]+num[m-1][n]; //这个就是递推的方法了(每个数等于它上方两数之和),例如3=1+2,3的坐标就是3[3,1]=1[2,0]+2[2,1];  
            }  
        } 
        
        for(int m=0;m<row;m++)//主要是输出数组  
        {  
            for(int k=row;k>=m;k--)//这个主要是打空格,好看一点,去掉就是直角三角形了  
            {  
                System.out.print(" ");  
            }  
            for(int n=row-m;n<=row;n++)//这个就是打印数组了,每层循环几次就几个  
            {  
                System.out.print(num[m][row-n]+" ");//不懂的可以把row替换成10,更加清楚点  
            }  
            System.out.println();//每层换行  
        }  
    }  


}
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值