倒序输出杨辉三角

题目描述:
Fans喜欢图形,而且喜欢把图形倒过来欣赏。有一次,他看见杨辉三角形 了,觉得很新鲜,于是就把它们大大小小地摆布出来。输入一些整数n(1≤n≤10),读入其每个整数,以该整数为行数,其画出来的倒杨辉三角形(每个数据 占三个字符)就是fans所喜欢欣赏的。Fans是手工做的,你却可以用编程更快捷地做出来,多爽啊!

输入:
5
3
输出:
1 4 6 4 1
1 3 3 1
1 2 1
1 1
1

1 2 1
1 1
1

思路:
解题思路:
1.先写出基本的杨辉三角的样式,存在数组当中。

2.然后倒着输出,找到倒着输出的规律就好了。记得数字的占位符的宽度应该和一次输出的空格的长度相等。

#include<cstdio>
#include <iostream>
using namespace std;
int main()
{
    int n;
    int a[10][10]={0};
    while(cin>>n)
    {
        for(int i=0;i<n;i++)
            for(int j=0;j<=i;j++)
            {
                if(j==0||j==i)
                    a[i][j]=1;
                else
                    a[i][j]=a[i-1][j-1]+a[i-1][j];
            }

        for(int i=0;i<n;i++)     //控制行数输出
        {
            for(int j=0;j<i;j++) // 控制空格输出,第一行不输出空格,第二个一个,j只要小于i,每次循环自会输出一个空格
                printf(" ");
            for(int k=0;k<n-i;k++)     //控制列数元素 
            {
                printf("%3d",a[n-i-1][k]);  //按三个位置来输出元素,n-i-1为当前行数
                printf(" ");
            }
            printf("\n");
        }
            return 0;

    }


    }
    }


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