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