输入行数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个字符