#include<stdio.h>
char buf[82][82];
int main(){
int n,m,i,j,cnt;
char in,out;
bool firstcase=true;
while(scanf("%d %c %c",&n,&in,&out)==3){
if(firstcase==true){
firstcase=false;
}
else printf("\n");
m=(n+1)/2;
if(m%2==0){
for(cnt=1;cnt<=m;cnt++){
for(i=cnt;i<=n-cnt+1;i++){
for(j=cnt;j<=n-cnt+1;j++){
if(cnt%2==1){
buf[i][j]=out;
}
else buf[i][j]=in;
}
}
}
}
if(m%2==1){
for(cnt=1;cnt<=m;cnt++){
for(i=cnt;i<=n-cnt+1;i++){
for(j=cnt;j<=n-cnt+1;j++){
if(cnt%2==1){
buf[i][j]=in;
}
else buf[i][j]=out;
}
}
}
}
if(n!=1){
buf[1][1]=buf[1][n]=buf[n][1]=buf[n][n]=' ';
}
for(i=1;i<=n;i++){
for(j=1;j<=n;j++){
printf("%c",buf[i][j]);
}
printf("\n");
}
}
return 0;
char buf[82][82];
int main(){
int n,m,i,j,cnt;
char in,out;
bool firstcase=true;
while(scanf("%d %c %c",&n,&in,&out)==3){
if(firstcase==true){
firstcase=false;
}
else printf("\n");
m=(n+1)/2;
if(m%2==0){
for(cnt=1;cnt<=m;cnt++){
for(i=cnt;i<=n-cnt+1;i++){
for(j=cnt;j<=n-cnt+1;j++){
if(cnt%2==1){
buf[i][j]=out;
}
else buf[i][j]=in;
}
}
}
}
if(m%2==1){
for(cnt=1;cnt<=m;cnt++){
for(i=cnt;i<=n-cnt+1;i++){
for(j=cnt;j<=n-cnt+1;j++){
if(cnt%2==1){
buf[i][j]=in;
}
else buf[i][j]=out;
}
}
}
}
if(n!=1){
buf[1][1]=buf[1][n]=buf[n][1]=buf[n][n]=' ';
}
for(i=1;i<=n;i++){
for(j=1;j<=n;j++){
printf("%c",buf[i][j]);
}
printf("\n");
}
}
return 0;
}
注意:
1. 边界数据处理 如本题 n=1时,应注意不要修改边角
2.输出格式 题目要求叠筐间有空行 所以在循环外定义是否第一组的布尔值 然后在循环中除第一次外 均先输出空行
本文介绍了一种使用C语言实现的算法,通过输入矩阵的大小和两种字符,生成一个具有特定对称性的复杂矩阵图案。算法根据不同条件调整矩阵元素的填充,确保输出的图案符合指定规则。
1004

被折叠的 条评论
为什么被折叠?



