#include <stdio.h>
int main()
{
int n,i,x,y;
while(scanf("%d",&n)!=EOF)
{
for(i=1;i<=n;i++)
{
for(x=1;x<=n-i;x++)
printf(" ");
for(y=n-i+1;y<n+i && y>n-i;y++)
printf("*");
printf("\n");
}
}
return 0;
}
这个金字塔,刚开始想了好久,以为需要用字符串数组来控制*号和空格的位置,后来搞半天行不通,自己以为*左边和右边都有空格,怎么用一个循环打印出两边的隔开的空格呢,查询资料发现,只有*号左边有空格,右边根本没有,于是就知道了空格的循环内容了。打印*号时候,从第一个*号开始打印,第一个*号,第一行,*号;列数为n,第二行为n-1,第三行,n-2,依次发现第一个*号位置为n-i+1,从此处开始打印,范围为n-i<<n+i,这样,金字塔的*符号就出来了。嘿嘿。整体看,蛮好看的哟。。。
现在也有很多数字金字塔,这些大体框架是一样的,在这里就不多说了。。。