xtu oj 1327 字符矩阵
2023-12-13 06:12:25
按照示例的规律输出字符矩阵。 比如输入字母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)){
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这道题类似。
文章来源:https://blog.csdn.net/m0_75005390/article/details/134955715
本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。 如若内容造成侵权/违法违规/事实不符,请联系我的编程经验分享网邮箱:veading@qq.com进行投诉反馈,一经查实,立即删除!
本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。 如若内容造成侵权/违法违规/事实不符,请联系我的编程经验分享网邮箱:veading@qq.com进行投诉反馈,一经查实,立即删除!