输入行数n,打印n行的金字塔。如图:
先分析其规律。
打印n行,即外层循环n次。再分析每一层的规律,先具体化举例,举一个行数为5的金字塔。可以发现每一行前面的空格呈递减趋势,且与行数有关系:空格数=行数-层数。输出字符随行数呈递增趋势,这就更明显了:字符数=行数。
以下是代码实现:
- #include
-
- 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
-
- 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个字符