7-21 剥洋葱

7-21 剥洋葱

题目描述:

布告,布告! 应老师要求,我们要做一道打印图形的题目,这是程序员最基本的能力。 那废话不多说,我们来说要求的图形 AAAAA ABBBA ABCBA ABBBA AAAAA 就是外到内,从A到Z。每一层都是一种字母,最里面的一层为一个,即最中心的一个。

输入格式:

一行,一个整数,即图形的层数。

输出格式:

如上述图形。

样例输出:

在这里插入图片描述

思路分析:

这道题一开始的时候,以为只是简单打印,但慢慢看下来还挺有意思的,我们可以直接分析他第一层外层边界是A,里面的字母全为A,第二层边界为AB,里面全为B,第三层边界为ABC,里面为C,那么可以得出规律,每一层外层边界增加一个字母,每一层最里面的字母,向后递推。已经得出规律,废话不多说,直接上代码。

代码:

#include<stdio.h>
int main()
{
	int a,b,d,e,g;
	char c1='A';//首字母为’A‘ 。 
	scanf("%d",&a);
	d=2*a-1;//计算每层有多少个字母。 
	for(int c=0;c<=a-1;c++) //输出上层数 
	{
		for(b=0;b<c;b++)
		{
			printf("%c",c1+b); //输出外层边界 
		}
		for(e=1;e<d-(2*c);e++)//输出内部字母 
		{
			printf("%c",c1+c);
		}
		for(g=d-c;g<=d;g++)//输出 外层边界 
		{
			printf("%c",c1+d-g);
		}
		printf("\n");
	}
	for(int c=a-2;c>=0;c--)//输出下层 数 
	{
		for(b=0;b<c;b++)//输出外层边界 
		{
			printf("%c",c1+b); 
		}
		for(e=1;e<d-(2*c);e++)//输出内部字母 
		{
			printf("%c",c1+c);
		}
		for(g=d-c;g<=d;g++)//输出 外层边界
		{
			printf("%c",c1+d-g);
		}
		printf("\n");
	}
}

总结:

这道题慢慢找,因为他是对称的,所以只要找出一边规律,另一边相反即可。曾经做过一道和他很类似的,打印沙漏,有兴趣可以去看看,下面给出打印沙漏的题解。

打印沙漏:

打印沙漏的题目链接

  • 1
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值