#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.输出格式 题目要求叠筐间有空行 所以在循环外定义是否第一组的布尔值 然后在循环中除第一次外 均先输出空行