XTU OJ 1277 Triangle

题目描述

给定一个字母,请输出其对应的字母三角形(最后一行行首,每行末无空格)。 比如输入E,输出

         A
        ABA
       ABCBA 
      ABCDCBA
     ABCDEDCBA
    A         A
   ABA       ABA 
  ABCBA     ABCBA 
 ABCDCBA   ABCDCBA
ABCDEDCBA ABCDEDCBA

输入

存在多个样例,每行输入一个大写字母。

输出

依次输出每个字符对应的字符三角形。

样例输入

A
B
C

样例输出

 A
A A
   A
  ABA
 A   A
ABA ABA
     A
    ABA
   ABCBA
  A     A
 ABA   ABA 
ABCBA ABCBA

思路:对于打图形的题目,个人喜欢分部分去打。 

#include<stdio.h>
int main()
{
	int n,i,j,k,k1,x,n1;
	char ch;
	while(scanf("%c",&ch)!=EOF)
	{
		n=ch-'A'+1;
		n1=n;
		for(i=1;i<=n;i++)//上半部分 
		{
			for(j=1;j<=2*n-i;j++)//前部分空格 
			{
				printf(" ");
			}
			x=1;
			for(j=1;j<=2*i-1;j++)//字母三角形 
			{
				if(j<=i)
				{
					printf("%c",x+65-1);
					x++;
				}
				if(j>i)
				{
					printf("%c",(x-2)+65-1);
					x--;
				}	
			}
			puts("");
		}
		for(i=1;i<=n;i++)//下半部分 
		{
			for(j=1;j<=n-i;j++)//前面空格部分 
			{
				printf(" ");
			}
			k=1;		
			for(j=1;j<=2*i-1;j++)//中间字母三角形 
			{
				if(j<=i)
				{
					printf("%c",k+65-1);
					k++;
				}
				if(j>i)
				{
					printf("%c",(k-2)+65-1);
					k--;
				}
			}
			for(j=1;j<=2*n1-1;j++)//中间的空格 
			{
				printf(" ");// n1 的作用是控制空格数
			}
			n1--;
			k1=1;
			for(j=1;j<=2*i-1;j++)//后面的字母三角形 
			{
				if(j<=i)
				{
					printf("%c",k1+65-1);
					k1++;
				}
				if(j>i)
				{
					printf("%c",(k1-2)+65-1);
					k1--;
				}
			}
			puts("");	
		}	
	}
	return 0;
}

 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值