当前位置: 代码迷 >> 综合 >> acm 2074
  详细解决方案

acm 2074

热度:28   发布时间:2023-12-22 07:28:54.0

提交了很多遍才过得,原来用这种方法,当输入是1 的时候就是错的,所以1要特殊处理

 

#include<stdio.h>
#include<string.h>
int main()
{
char map[81][81],a[2],b[2];
int flag=0,num,i,j,k;
char c;

while(scanf("%d%s%s",&num,b,a)==3)
{
if(!flag)
 ++flag;
else
printf("\n");
 if(num==1)
 {
  printf("%c\n",b[0]);
  continue;
 }

memset(map,0,sizeof(map));
k=num/2+1;
 
   if(k%2==0)
       c=a[0];
 else
  c=b[0];
for(i=1;i<=k;i++)
{
 
for(j=i;j<=num+1-i;j++)
{if(map[j][i]==0)
  map[j][i]=c;
if(map[i][j]==0)
  map[i][j]=c;
if(map[num+1-i][j]==0)
  map[num+1-i][j]=c;
if( map[j][num+1-i]==0)
  map[j][num+1-i]=c;


}

c=(c==a[0]?b[0]:a[0]);


}

 

map[1][1]=' ';
map[1][num]=' ';
map[num][1]=' ';
map[num][num]=' ';
for(i=1;i<=num;i++)
{
   for(j=1;j<=num;j++)
      printf("%c",map[i][j]);
printf("\n");

}

 

}
return 0;
}