1026 - 镂空三角形

通过次数

0

提交次数

0

时间限制 : 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();
						
			}
			
				}
			
}