【C语言】用for循环实现打印星星类菱形(两种方法超详细)

  时间:2020-08-25 11:49:53  阅读量:1.9k+  评论数:0  作者:dragonFloor

学习编程,分析源码很重要,【C语言】用for循环实现打印星星类菱形(两种方法超详细)这篇文章通过代码举例讲述得比较清晰,想了解的可以参考学习一下。

下面就是用C语言的for循环写的详细的关于实现星星类菱形的代码,注释分析比较详细,仅供参考,如有错误或可优化的地方,欢迎读者斧正。

画出图像然后把左边空格当成1,方便看和分析。

先考虑前n行,再处理剩下的n-1行。

        1111*
        111***
        11*****
        1*******
        *********
        1*******
        11*****
        111***
        1111*
//VS系列编译器中不用此定义会出现非法错误
/*错误  error C4996: 'scanf': This function or variable may be unsafe. Consider using scanf_s instead. To disable deprecation, use _CRT_SECURE_NO_WARNINGS. See online help for details. */

#define  _CRT_SECURE_NO_WARNINGS
#include<stdio.h>
#include<stdlib.h>
int main()
{
 //由菱形几何性质可知中间行的行数即为菱形的半径
 int n = 0;                  //初始化n
 
 printf("请输入星星菱形边长:");
 
 scanf("%d", &n);            //输入n
 
 for (int i = 1; i <= n; i  )//定义从第1行到第n行外循环
  {    
  
  //随着外循环i的增大(行数的增加)n-i依次变小(图中1依次变小) 
  //与行数变化相反,所以采取递减
  //处理左方空白 
    //当n=5时 上半部分图像如下图,空白用1表示 
    /*      1111*
            111***
            11*****
            1*******
            *********
    */        
   //根据等差数列
   /*
       行数:1   2   3   4   5
   星的个数:1   3   5   7   9
   易得行数i与对应行星星个数k满足的通项公式 k=2*i-1  注意此处2*i不可省略为2i
   */
   
   
         
  for (int j = n - i; j>=1; j--)    
   {                                 
   
      printf(" ");                         
                                   
   }
  for (int k = 1; k <= 2 * i-1 ;k  ) //等差数列公式
   {
      printf("*");
   }
      printf("\n");//对每行操作后换行
  }

   // 下面是从第n 1行开始倒序操作
 
  for (int i = n-1; i >=1; i--)//之前处理了n行,所以接下来处理剩下的n-1行
 {
  for (int j = 1; j <= n-i; j  )                 //           1*******
  {                                              //           11*****
   printf(" ");                                  //           111***
  }                                              //           1111*
  for (int k = 1; k <= 2 * i-1; k  )
  {
   printf("*");
  }
  printf("\n");
 }
 //以下是另一种解法正序操作,即把剩下的n-1行当做新的序列从1开始
 for (int i = 1; i <= n - 1; i  )
 {
  for (int j = 1; j <= i; j  )
  {
   printf(" ");
  }
  //此时要求得行数与对应行星星个数的函数关系
  //首(行)项为2n-3,公差为-2(依次递减),规律变化行数为i,则通过等差数列通项公式:通项=首项 公差*(i-1)
  //则2*n-3-2*(i-1)=2*n-2*i-1即为i行星星数的通项
  for (int k = 1; k <= 2 * n - 2 * i - 1; k  )
  {
   printf("*");
  }
  printf("\n");
 }
 system("pause");
 return 0;
}
                               

关键词:c语言,语言,for,for循环,循环,实现,打印,星星,菱形,两种,方法,法超,详细