打印沙漏 打印沙漏

打印沙漏

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





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

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

输入格式:
输入在一行给出1个正整数N(≤1000)和一个符号,中间以空格分隔。

输出格式:
首先打印出由给定符号组成的最大的沙漏形状,最后在一行中输出剩下没用掉的符号数。

输入样例:
19
输出样例:
****
***



  • 2
    (1)实验代码

'''

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

'''

  • 二.思路:先定义所需要的行数,以及所给的数目, 再计算所需要的行数,然 后先计算上部分每行所需要的空格,再按规律换行,最后
    再以同样的方式计算下半部分,再输出。

猜你喜欢

转载自www.cnblogs.com/shadowzzz/p/10376032.html