xtu oj 1327 字符矩阵

按照示例的规律输出字符矩阵。 比如输入字母D时,输出字符矩阵如下

复制代码
ABCDCBA
BBCDCBB
CCCDCCC
DDDDDDD
CCCDCCC
BBCDCBB
ABCDCBA

字符矩阵行首、尾都无空格。

输入

每行一个大写英文字母,如果字符为#,表示输入结束,不需要处理。

输出

依次输出对应的字符矩阵

样例输入

复制代码
A
B
C
#

样例输出

复制代码
A
ABA
BBB
ABA
ABCBA
BBCBB
CCCCC
BBCBB
ABCBA

AC代码

cs 复制代码
#include<stdio.h>
int main()
{
	char str;
	while(scanf("%c",&str)){
		if(str=='#')break;
		int i,j;
		char a[55][55]={};
		int n=str-'A'+1;
		int len=2*n-1;
		for(i=1;i<=len/2+1;i++){
			for(j=i;j<=len/2+1;j++){
				a[i][j]=j+'A'-1;
			}
			for(j=len/2+2;j<=len+1-i;j++){
				a[i][j]=len-j+'A';
			}
		}
		for(i=2;i<=len/2+1;i++){
			for(j=1;j<=i-1;j++){
				a[i][j]=i-1+'A';
			}
			for(j=len+2-i;j<=len;j++){
				a[i][j]=i-1+'A';
			}
		}
		for(i=len/2+2;i<=len;i++){
			for(j=len+1-i;j<=len/2+1;j++){
				a[i][j]=j-1+'A';
			}
			for(j=len/2+2;j<=i;j++){
				a[i][j]=len-j+'A';
			}
		} 
		for(i=len/2+2;i<=len-1;i++){
			for(j=1;j<=len-i;j++){
				a[i][j]=len-i+'A';
			}
			for(j=i+1;j<=len;j++){
				a[i][j]=len-i+'A';
			}
		}
		for(i=1;i<=len;i++){
			for(j=1;j<=len;j++){
				printf("%c",a[i][j]);
			}
			printf("\n");
		}
	}
 } 

解题思路:利用二维数组找规律进行分块打印即可。此题与前面1233 Cycle Matric这道题类似。

相关推荐
加号38 小时前
【C#】 串口通信技术深度解析及实现
开发语言·c#
心中有国也有家10 小时前
cann-recipes-infer:昇腾 NPU 推理的“菜谱集合”
经验分享·笔记·学习·算法
绝知此事10 小时前
【算法突围 01】线性结构与哈希表:后端开发的收纳术
java·数据结构·算法·面试·jdk·散列表
无风听海10 小时前
C# 隐式转换深度解析
java·开发语言·c#
碧海银沙音频科技研究院10 小时前
通话AEC与语音识别AEC的软硬回采链路
深度学习·算法·语音识别
LateFrames10 小时前
520 - 如何说晚安 (WPF)
c#·wpf·浪漫·ui体验
csdn_aspnet11 小时前
Python 算法快闪 LeetCode 编号 70 - 爬楼梯
python·算法·leetcode·职场和发展
LuminousCPP11 小时前
数据结构 - 线性表第四篇:C 语言通讯录优化升级全记录(踩坑 + 思考)
c语言·开发语言·数据结构·经验分享·笔记·学习
魔法阵维护师11 小时前
从零开发游戏需要学习的c#模块,第十四章(保存和加载)
学习·游戏·c#