打印杨辉三角,重要的是观察出其特点,然后简化思维进行解决,第一列的所有元素都是1,而对角线上的所有元素也是1,其他位置的元素是其上一行对应两个元素的和,其代码如下:
#include<stdio.h>
int main()
{
int arr[10][10] = { 0 };
int i = 0;
int j = 0;
for (i = 0; i < 10; i++)
{
for (j = 0; j <=i; j++)
{
if (j == 0)//第一列元素全为1
{
arr[i][j] = 1;
}
else if (i == j)//对角线上的元素全为1
{
arr[i][j] = 1;
}
else//其余元素为其上一行对应两个元素之和
{
arr[i][j] = arr[i - 1][j] + arr[i - 1][j - 1];
}
}
}
for (i = 0; i < 10; i++)
{
for (j = 0; j <= i; j++)
{
printf("%d", arr[i][j]);
}
printf("\n");
}
return 0;
}