打印沙漏编程总结

7-1 打印沙漏 (20 分)

本题要求你写个程序把给定的符号打印成沙漏的形状。例如给定17个“*”,要求按下列格式打印

*****
 ***
  *
 ***
*****

所谓“沙漏形状”,是指每行输出奇数个符号;各行符号中心对齐;相邻两行符号数差2;符号数先从大到小顺序递减到1,再从小到大顺序递增;首尾符号数相等。

给定任意N个符号,不一定能正好组成一个沙漏。要求打印出的沙漏能用掉尽可能多的符号。

1、实验代码

#include<stdio.h>
  int main()
  {
      int n;
      char c;
      scanf("%d %c",&n,&c);
      int i=1,sum=1;  
      while(sum<=n)
      {
         sum+=2*(2*(i+1)-1);  
         i++;
     }
     i=i-1;   
     
     int j,k;
     
     for(j=0;j<i;j++)   
     {
         for(k=0;k<j;k++)
         printf(" ");  
         for(k=0;k<2*(i-j)-1;k++)  
         {
             printf("%c",c);  
         }
         printf("\n");  
      } 
      
     
     for(j=2;j<=i;j++)  
     {
         for(k=0;k<i-j;k++)  
        printf(" ");
         for(k=0;k<2*j-1;k++)
         {
             printf("%c",c);
         }
         printf("\n");
     } 
     printf("%d",n-(sum-2*(2*(i+1)-1)));      
    return 0;
 }

2、设计思路

第一步:先找出该题的突破点,很明显,这道题要求的沙漏是一个对称的形状;
第二步:再确定图形中字符个数是等差这么个规律,空格的个数可以根据每一行来确定;
第三步:利用等差求和公式,先计算所输入数字能输出的最大沙漏所需要的字符数,在计算总字符数时,注意细节,多算的最后要减去;
第四步:分两部分写,先打印上半部分,再打印下半部分;
第五步:输出结果,注意求余数时,要记得算总数时多加了,要减去。

3、本题调试过程碰到的问题及解决方法

说实话这道题一开始我并不会,是在借鉴别人的代码后,自己又看看才弄懂的。所以.....问题还是有的,而且很大。

4、运行结果截图

忘记截了,时间过了......

猜你喜欢

转载自www.cnblogs.com/songguanhao/p/10295289.html