int i, j, k, n=0, a[20][20];
while(n<=0||n>=13){ //控制打印的行数不要太大,过大会造成显示不规范
printf("请输入要打印的行数:");
scanf("%d",&n);
}
printf(" %d 行杨辉三角如下:\n",n);
for(i=1;i<=n;i++)
a[i][1] = a[i][i] = 1; //两边的数令它为1,因为现在循环从1开始,就认为a[i][1]为第一个数
for(i=3;i<=n;i++)
for(j=2;j<=i-1;j++)
a[i][j]=a[i-1][j-1]+a[i-1][j]; //除两边的数外都等于上两顶数之和
for(i=1;i<=n;i++){
for(k=1;k<=n-i;k++)
printf(" "); //这一行主要是在输出数之前打上空格占位,让输出的数更美观
for(j=1;j<=i;j++) //j<=i的原因是不输出其它的数,只输出我们想要的数
printf("%6d",a[i][j]);
printf("\n"); //当一行输出完以后换行继续下一行的输出
}
printf("\n");
/*-------------------反爬声明o(▽)咻咻咻--------------------
作者:杨木发
版权声明:
本文为博主倾情原创文章,整篇转载请附上源文链接!
如果觉得本文对你有所收获,你的请评论点赞 与
合理优质的转发也将是鼓励支持我继续创作的动力,
更多精彩可百度搜索 杨木发 或:
个人网站:https://www.yangmufa.com ,
GitHub:https://github.com/yangmufa ,
坚持创作 善于总结 开源共享 高质进步。
-------------------反爬声明o(▽)咻咻咻--------------------*/