c语言打印金字塔
输入行数n,打印n行的金字塔。如图:
先分析其规律。
打印n行,即外层循环n次。再分析每一层的规律,先具体化举例,举一个行数为5的金字塔。可以发现每一行前面的空格呈递减趋势,且与行数有关系:空格数=行数-层数。输出字符随行数呈递增趋势,这就更明显了:字符数=行数。
以下是代码实现:
#include <stdio.h>
int main(){
int n;
scanf("%d",&n);//输入行数
for(int i=1;i<=n;++i){
for(int j=n-i;j>0;--j){//输出空格,等于总行数-层数
printf(" ");
}
for(int k=1;k<=i;++k){//输出字符,等于行数。
printf("* ");
}
printf("\n");//每一层完,需要换行
}
return 0;
}
如果for循环看起来有点迷糊,可以改成while循环方便理解,以下是另一个版本:
#include <stdio.h>
int main(){
int n;
scanf("%d",&n);//输入行数
for(int i=1;i<=n;++i){
int kongge=n-i; //空格数=总行数-层数
while(kongge--){
printf(" ");
}
int zifu=i;//字符=行数
while(zifu--){
printf("* ");
}
printf("\n");//每一层完,需要换行
}
return 0;
}
知道了这个规律。那Python一个循环就能搞定,根据Python语言的特点,可以直接输出字符串✖数量。 以下是Python语言实现:
n=int(input()) #输入行数
for i in range(1,n+1):
print(" "*(n-i),end=' ')#输出(n-1)空格数
print("* "*i)#输出i个字符