xtu oj 1327 字符矩阵

时间:2024-02-17 09:11:26

题目描述

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

ABCDCBA
BBCDCBB
CCCDCCC
DDDDDDD
CCCDCCC
BBCDCBB
ABCDCBA

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

输入

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

输出

依次输出对应的字符矩阵

样例输入

A
B
C
#

样例输出

A
ABA
BBB
ABA
ABCBA
BBCBB
CCCCC
BBCBB
ABCBA

AC代码

#include<stdio.h>
int main(){
	char str;
	while(scanf("%c",&str)&&str!='#'){
		char a[55][55]={};
		int i,j,n=str-'A'+1;
		int t=2*n-1;
		for(i=1;i<=n;i++){
			for(j=i;j<=n;j++){
				a[i][j]='A'+j-1;
			}
			for(j=n+1;j<=2*n-i;j++){
				a[i][j]='A'+t-j;
			}
		}
		for(i=2;i<=n;i++){
			for(j=1;j<=i-1;j++){
				a[i][j]='A'+i-1;
			}
			for(j=t+2-i;j<=t;j++){
				a[i][j]='A'+i-1;
			}
		}
		for(i=n+1;i<=t;i++){
			for(j=1;j<=t-i;j++){
				a[i][j]='A'-i+t;
			}
			for(j=t+1-i;j<=n;j++){
				a[i][j]='A'+j-1;
			}
			for(j=n+1;j<=i;j++){
				a[i][j]='A'+t-j;
			}
			for(j=i+1;j<=t;j++){
				a[i][j]='A'-i+t;
			}
		}
		for(i=1;i<=t;i++){
			for(j=1;j<=t;j++){
			  printf("%c",a[i][j]);
			}
			printf("\n");
		}
	}
}