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个字符