團隊天梯賽L1-002

本題要求你寫個程序把給定的符號打印成沙漏的形狀。例如給定17個“*”,要求按下列格式打印

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

所謂“沙漏形狀”,是指每行輸出奇數個符號;各行符號中心對齊;相鄰兩行符號數差2;符號數先從大到小順序遞減到1,再從小到大順序遞增;首尾符號數相等。

給定任意N個符號,不一定能正好組成一個沙漏。要求打印出的沙漏能用掉儘可能多的符號。

輸入格式:

輸入在一行給出1個正整數N(<=1000)和一個符號,中間以空格分隔。

輸出格式:

首先打印出由給定符號組成的最大的沙漏形狀,最後在一行中輸出剩下沒用掉的符號數。

輸入樣例:

19 *

輸出樣例:

*****
 ***
  *
 ***
*****
2


#include <stdio.h>
 int main()
 {  
                                        //   hang :除最中心 * 一半的行列數  i: 循環行列次數  j :循環空格次數 k: 循環打印*次數  
  int hang,i,j,k,l,m=0,sum1,sum2;     
  char ch;                                  // sum1:最大沙漏的總數  sum2:輸入 * 數量  l 控制最中心 * 前的空格數
  scanf("%d %c",&sum2,&ch);
while (sum2>=2*(m*m+2*m)+1)           //等差數列求和(s=n*a1+n*(n-1)*d/2),求出構成沙漏最大行數hang
{
      m++;
    hang=m-1;                       
}
sum1=2*(hang*hang+2*hang)+1;   //完整的最大沙漏的總數sum1

 for(i=hang;i>=1;i--)         //打印下三角沙漏
 {
  for(j=0;j< hang-i;j++)   //空格遞增
     printf(" ");
  for(   k= i * 2 + 1; k>= 1;k--)    // * 遞減
     printf("%c",ch);
     printf("\n");
 }

  for ( l=hang; l>0; l--)     //打印中心*,空格數=行數
      printf(" ");
      printf("%c",ch);
    printf("\n");
 
for(i=1;i<=hang;i++)      //打印上三角沙漏
 {
  for(j=0;j< hang-i;j++)   //空格數遞減
     printf(" ");
  for(   k= i * 2 + 1; k>0;k--)    // *打印遞增
  printf("%c",ch);
  printf("\n");
 }

 printf("%d\n",sum2-sum1);    //輸出最後剩餘*數
 return 0;
 }


發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章