题目描述
按照示例的规律输出字符矩阵。 比如输入字母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");
}
}
}