7-66 打印杨辉三角(20 分)
2018-03-04 00:33
253 查看
这道题看似很简单,但实际上对于格式特别敏感。我一开始写完之后,提交格式错误,原本以为是因为换行,结果发现,其实是因为每一行开头的第一个字符所占的位数多了一位,一开始我计算每行首位前的空格时,想的是n-i+1个空格,因为i从0开始,如果有10行,那么第一行就应该是10-1=9个空格,而不是10-0+1个空格...刚才写的时候发现,一直在这里卡主真的很奇葩啊,估计我一直以为i从2开始吧... 还有就是这道题目每个数字都占4位,所以如果为第一行,那么1前面已经有3个空格了,要在这三个空格的基础上,在再前面计算出9个空格,也就是说,第一行的空格数应该为12个空格才对。我看见有的代码要单独计算第一行,感觉没有必要那么麻烦。附上代码。
/*
题目:杨辉三角
作者:Unis
日期:2018.3.3 Saturday
*/
#include<stdio.h>
int main(){
const int maxn = 10;
int ans[maxn][maxn];
int n;
scanf("%d",&n);
for(int i = 0;i < n;i++){
for(int j = 0;j < n-i-1;j++){//10-9-1=0
printf(" ");
}
for(int j = 0;j < i+1;j++){
if(i >= 2 && (j >= 1 && j < i)){
ans[i][j] = ans[i-1][j-1] + ans[i-1][j];
}
else{
ans[i][j] = 1;
}
printf("%4d",ans[i][j]);
}
printf("\n");
}
return 0;
}
/*
题目:杨辉三角
作者:Unis
日期:2018.3.3 Saturday
*/
#include<stdio.h>
int main(){
const int maxn = 10;
int ans[maxn][maxn];
int n;
scanf("%d",&n);
for(int i = 0;i < n;i++){
for(int j = 0;j < n-i-1;j++){//10-9-1=0
printf(" ");
}
for(int j = 0;j < i+1;j++){
if(i >= 2 && (j >= 1 && j < i)){
ans[i][j] = ans[i-1][j-1] + ans[i-1][j];
}
else{
ans[i][j] = 1;
}
printf("%4d",ans[i][j]);
}
printf("\n");
}
return 0;
}
相关文章推荐
- PAT数组-02. 打印杨辉三角(20)
- 数组-02. 打印杨辉三角(20)
- 数组-02. 打印杨辉三角(20)
- 数组-02. 打印杨辉三角(20)
- 7-15 打印杨辉三角(20 分)
- 数组-02. 打印杨辉三角(20)
- 数组-02. 打印杨辉三角(20)
- 数组-02. 打印杨辉三角(20)
- 7-4 打印杨辉三角
- 5-20 打印九九口诀表
- 打印-杨辉三角
- 1027. 打印沙漏(20)
- 1027. 打印沙漏(20)
- 1027. 打印沙漏(20) (模拟啊数学啊 ZJU_PAT)
- 打印杨辉三角--for循环
- 编写一个程序,在屏幕上打印杨辉三角
- 剑指offer面试题20 顺时针打印矩阵
- 超级标准形式打印杨辉三角
- 1027. 打印沙漏(20)-浙大PAT乙级真题java实现
- 1027. 打印沙漏(20) python篇