HDU2091 空心三角形



Problem Description
把一個字符三角形掏空,就能節省材料成本,減輕重量,但關鍵是爲了追求另一種視覺效果。在設計的過程中,需要給出各種花紋的材料和大小尺寸的三角形樣板,通過電腦臨時做出來,以便看看效果。
 

Input
每行包含一個字符和一個整數n(0<n<41),不同的字符表示不同的花紋,整數n表示等腰三角形的高。顯然其底邊長爲2n-1。如果遇到@字符,則表示所做出來的樣板三角形已經夠了。
 

Output
每個樣板三角形之間應空上一行,三角形的中間爲空。顯然行末沒有多餘的空格。
 

Sample Input
X 2A 7@
 

Sample Output
XXXX  A A A A A A A A A A AAAAAAAAAAAAAA
Problem Description
把一個字符三角形掏空,就能節省材料成本,減輕重量,但關鍵是爲了追求另一種視覺效果。在設計的過程中,需要給出各種花紋的材料和大小尺寸的三角形樣板,通過電腦臨時做出來,以便看看效果。
 

Input
每行包含一個字符和一個整數n(0<n<41),不同的字符表示不同的花紋,整數n表示等腰三角形的高。顯然其底邊長爲2n-1。如果遇到@字符,則表示所做出來的樣板三角形已經夠了。
 

Output
每個樣板三角形之間應空上一行,三角形的中間爲空。顯然行末沒有多餘的空格。
 

Sample Input
X 2A 7@
 

Sample Output
XXXX  A A A A A A A A A A AAAAAAAAAAAAAA

這道題坑的地方在格式= =輸出的第一個三角形沒有\n,之後的纔有\n,就是如下這樣的輸入輸出


#include<stdio.h>
#include<string.h>
int main()
{
   char a;
   int n,t,i,j,count=1;
   while(scanf("%c%d",&a,&n)&&a!='@')
   {
        getchar();
        if(count!=1)
            printf("\n");
       for(t=1;t<=n;t++)
       {
           if(t==1)
           {
             for(i=1;i<=n-1;i++)
               printf(" ");
            printf("%c",a);
            printf("\n");
           }
           else if(t==n)
           {
               for(i=1;i<=2*n-1;i++)
                printf("%c",a);
               printf("\n");
           }
           else
           {
              for(i=1;i<=n-t;i++)
                printf(" ");
               printf("%c",a);
               for(j=1;j<=2*t-3;j++)
                printf(" ");
               printf("%c",a);
               printf("\n");
           }
       }
       count=0;
   }
   return 0;
}

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