空心三角形
Time Limit: 1000/1000 MS (Java/Others) Memory Limit: 32768/32768 K (Java/Others)
Total Submission(s): 49981 Accepted Submission(s): 13524
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
Author
qianneng
Source
第i行前面有 n - i 个空格,然后接下来有 2 * i - 1 个字符,其中前后两个为输入字符其余2 * i - 3个字符均为空格(i=1时除外,只有一个输入字符)
每两个三角形之间有一个换行符
#include<iostream>
#include<string.h>
#include<stdio.h>
using namespace std;
int n, cnt = 0;
char ch;
int main()
{
while(scanf("%c",&ch)&&ch!='@'){
if(cnt++) printf("\n");
scanf("%d",&n);
getchar();//换行符
for(int i=1;i<n;i++){
for(int j=i;j<n;j++) printf(" ");
printf("%c",ch);
if(i==1){
printf("\n");
continue;
}
for(int j=0;j<1+(i-2)*2;j++) printf(" ");
printf("%c\n",ch);
}
for(int j=0;j<=(n-1)*2;j++) printf("%c",ch);
printf("\n");
}
return 0;
}