int main()
{
int n = 0;
int i = 0;
int j = 0;
int m = 0;
scanf("%d", &n);
for (i = 1; i <= n; i++)
{
for (m = i; m < n; m++)
{
printf(" ");
}
for (j = 1; j <= 2 * i - 1; j++)
{
printf("*");
}
printf("\n");
}
return 0;
}
思路:显然这是循环嵌套,分别循环空格和*号;而且空格必须在*号之前执行,否者空格输出无效。
如输出3,则图形为 *
***
*****,*号输出为奇数项,空格输出为2,1,0
外循环行数,这个容易写出判断条件i<=n(n为循环次数,即行数)
*号循环,奇数项表示为2n-1,但内循环应为2*i-1,分别执行1,3,5 的判断条件。每次执行分别为对应次数的*。所以直接打印*
空格的循环(在这里遇到了障碍),执行第一次时为两个空格,需循环两次,若小于n(此时为3)的话,成立;第二次循环首项为2,即一次,所以将i作为首项;如果n为5,6,貌似金字塔也成立。所以判断条件为m<n,i赋给m;