墨文和 发表于 2021-12-15 22:16:11

请教一下这题的原理

这是一个打印正三角形的程序 :
代码如下:
#include <stdio.h>
int main()
{
        inta,b,c,n;
        printf("请输入整数N作为三角形行数:");
        scanf("%d",&n);
        printf("输出三角形如下:\n");
        for(a=1;a<=n;a++)
{
    for(b=n;b>=a;b--)
    {
   printf(" ");
    }
    for(c=1;c<=2*a-1;c++)
    {
   printf("*");
   }
      printf("\n");//正三角形
}
}
想问一下为什么c<2*a-1{:10_266:}
谢谢

jackz007 发表于 2021-12-15 22:37:18

本帖最后由 jackz007 于 2021-12-15 22:39 编辑

      第1行 a = 1 ,2 × 1 - 1 = 1
      第2行 a = 2 ,2 × 2 - 1 = 3
      第3行 a = 3 ,2 × 3 - 1 = 5
      第4行 a = 4 ,2 × 4 - 1 = 7
      第5行 a = 5 ,2 × 5 - 1 = 9
      答案就是 2 * a - 1 就是三角形第 a 行的循环次数,也就是打印出 '*' 的个数。
页: [1]
查看完整版本: 请教一下这题的原理