1027. 打印沙漏(20)

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

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

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

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

输入格式:

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

输出格式:

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

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

找沙漏的规律,*****只看上半部分的话,沙漏的是个等差数列(汗,高中数学0.0),等差为2,An=2n-1即Sn=n^2,

              ***

               *

所以*的总个数为sum=2*n*n-1


注意:1.*前有空格,*不能有

2.全用完了也要输出0


*******
#*****
##***
###*
##***
#*****
*******

(用#代表空格)上半部分从上往下顺序  *递减,#递增

下半部分从上往下*递增,#递减


[cpp]  view plain  copy
  1. #include<stdio.h>  
  2. #include<math.h>  
  3. int main()  
  4. {  
  5.     int sum=0,n,i=0,j=0,k=0;  
  6.     char ch;  
  7.       
  8.     while(~scanf("%d %c",&sum,&ch))  
  9.     {  
  10.         n=sqrt((sum+1)/2);  
  11.     //  printf("%d\n",n);   
  12.         for(i=0;i<n;i++)  
  13.         {  
  14.             for(j=0;j<i;j++)  
  15.                 printf(" ");  
  16.             for(k=2*n-2*i-1;k>0;k--)  
  17.                 printf("%c",ch);  
  18.             printf("\n");     
  19.         }  
  20.         for(i=1;i<n;i++)  
  21.         {  
  22.             for(j=n-i-1;j>0;j--)  
  23.                 printf(" ");  
  24.             for(k=0;k<2*i+1;k++)  
  25.                 printf("%c",ch);  
  26.             printf("\n");     
  27.         }  
  28.         printf("%d\n",sum-2*n*n+1);  
  29.           
  30.     }  
  31.       
  32.     return 0;  
  33. }  

猜你喜欢

转载自blog.csdn.net/dovis233/article/details/79780467