杭电2091 空心三角形

Problem Description
把一个字符三角形掏空,就能节省材料成本,减轻重量,但关键是为了追求另一种视觉效果。在设计的过程中,需要给出各种花纹的材料和大小尺寸的三角形样板,通过电脑临时做出来,以便看看效果。
 

Input
每行包含一个字符和一个整数n(0<n<41),不同的字符表示不同的花纹,整数n表示等腰三角形的高。显然其底边长为2n-1。如果遇到@字符,则表示所做出来的样板三角形已经够了。
 

Output
每个样板三角形之间应空上一行,三角形的中间为空。显然行末没有多余的空格。
 

Sample Input
   
   
   
   
X 2 A 7 @
 

Sample Output
   
   
   
   
X XXX   A A A A A A A A A A A AAAAAAAAAAAAA
 


#include<stdio.h>
int main()
{
    int a[50][100];
    int i,j,k;
    int n;
    char ch;
    int flag=0;
    while(~scanf("%c",&ch)&&ch!='@')
    {
        scanf("%d",&n);
        getchar();  //这个一定要加,否则第二次数据会出错 
        if(flag) printf("\n");
        for(i=1;i<n;++i)
        {
            for(j=1;j<=n-i;++j) printf(" ");
            
            printf("%c",ch);
            if(i==1) {
                printf("\n");
                continue;
            }
            else
            {
                for(k=1;k<=2*i-3;++k)
                    printf(" ");
                printf("%c\n",ch);
            }
        }
        for(j=1;j<=2*i-1;++j)
            printf("%c",ch);
        printf("\n");
        flag=1;
    }   
    return 0;
}


你可能感兴趣的:(杭电2091 空心三角形)