C# 实现杨辉三角

                      杨辉三角
 

一 历史:

   杨辉三角,是二项式系数在三角形中的一种几何排列。在中国南宋数学家杨辉的《详解九章算法》一书中出现。

《C# 实现杨辉三角》

二 特点:

(1)第一列和最后一列的数值为1
(2)中间列,数值等于它上方两数之和
《C# 实现杨辉三角》

三 编程实现:

1.直角杨辉三角

using System;
using System.Collections.Generic;
using System.Linq;
using System.Text;
using System.Threading.Tasks;
public class PascalTraingle
{
    public static void Main()
    {
        Console.WriteLine(“请输入长度:”);
        int length = Convert.ToInt32(Console.ReadLine());
        Console.WriteLine();

        int[,] array = new int[length,length];
        for (int i = 0; i < length; i++) { // 循环打印杨辉三角,length行
            
            for (int j = 0;j<=i; j++) //注意:j<=i, 因为第1行有1列,第2行有2列,第3行有3列。。。
            {
                if(j == 0 ||i==j)  //第一列和最后一列
                {
                    array[i, j] = 1; //值为1
                }
                else
                {
                    array[i, j] = array[i – 1, j – 1] + array[i – 1, j]; //中间列的值 = 上一行和它所在列-1的值 + 上一行和它所在列的值
                }



                Console.Write(array[i, j].ToString() + ” “); //打印值
            }
            Console.WriteLine();//每行打印完所有值后换行
        }
        Console.ReadKey();
    }

}

《C# 实现杨辉三角》

2.金字塔杨辉三角

using System;

using System.Collections.Generic;

using System.Linq;

using System.Text;

using System.Threading.Tasks;

public class PascalTraingle

{

    public static void Main()

    {

        Console.WriteLine(“请输入长度:”);

        int length = Convert.ToInt32(Console.ReadLine());

        Console.WriteLine();

        int[,] array = new int[length,length];

        for (int i = 0; i < length; i++) { // 循环打印杨辉三角,length行

            

            for (int k = 0; k < length – i; k++) //打印空格
            {
                Console.Write(” “);
            }

            for (int j = 0;j<=i; j++) //注意:j<=i, 因为第1行有1列,第2行有2列,第3行有3列。。。

            {

                if(j == 0 ||i==j)  //第一列和最后一列

                {

                    array[i, j] = 1; //值为1

                }

                else

                {

                    array[i, j] = array[i – 1, j – 1] + array[i – 1, j]; //中间列的值 = 上一行和它所在列-1的值 + 上一行和它所在列的值

                }

                Console.Write(array[i, j].ToString() + ” “); //打印值

            }

            Console.WriteLine();//每行打印完所有值后换行

        }

        Console.ReadKey();

    }

}

《C# 实现杨辉三角》

    原文作者:杨辉三角问题
    原文地址: https://blog.csdn.net/qq_39225721/article/details/80676667
    本文转自网络文章,转载此文章仅为分享知识,如有侵权,请联系博主进行删除。
点赞