1026 - 镂空三角形
时间限制 : 1 秒
内存限制 : 32 MB
把一个字符三角形掏空,就能节省材料成本,减轻重量,但关键是为了追求另一种视觉效果。在设计的过程中,需要给出各种花纹的材料和大小尺寸的三角形样板,通过电脑临时做出来,以便看看效果。
题目输入
每行包含一个字符和一个整数n(0<n<41),不同的字符表示不同的花纹,整数n表示等腰三角形的高。显然其底边长为2n-1。如果遇到@字符,则表示所做出来的样板三角形已经够了。
题目输出
每个样板三角形之间应空上一行,三角形的中间为空。显然行末没有多余的空格。
输入/输出样例
输入格式
X 2 A 7 @
输出格式
X
XXX
A
A A
A A
A A
A A
A A
AAAAAAAAAAAAA
C语言解答
#include<stdio.h> int main() { int n,i=0; char c; while((c=getchar())!='@') { scanf("%d%*c",&n); printf(i?"\n%*c\n":"%*c\n",n,c); if(n==1) { i=1; continue; } for(i=1;i<n-1;i++) printf("%*c%*c\n",n-i,c,2*i,c); for(i=0;i<2*n-1;i++) printf("%c",c); printf("\n"); } return 0; }
C++解答
#include<stdio.h> int main() { int n,i=0; char c; while((c=getchar())!='@') { scanf("%d%*c",&n); printf(i?"\n%*c\n":"%*c\n",n,c); if(n==1) { i=1; continue; } for(i=1;i<n-1;i++) printf("%*c%*c\n",n-i,c,2*i,c); for(i=0;i<2*n-1;i++) printf("%c",c); printf("\n"); } return 0; }
Java解答
import java.util.Scanner; public class Main { public static void main(String[] args) { Scanner s=new Scanner(System.in); String c;int i,j,k,n; while(s.hasNext()) { if((c=s.next()).equals("@")) { break; } n=s.nextInt(); for ( i = 0; i < n-1; i++) { for ( j = 0; j < n-i-1; j++) System.out.print(" "); System.out.print(c); for (k = 0; k < 2*i-1; k++) System.out.print(" "); if(i!=0) System.out.println(c); else System.out.println(); } for(int l=0;l<2*n-1;l++) { System.out.print(c); } System.out.println(); System.out.println(); } } }