又是一道模拟题,采用枚举的方法就可
#include<iostream>
using namespace std;
int i,j,Maze[4][4],min_step;
void change(int i,int j)
{
for(int t=0;t<4;t++)
Maze[i][t]++;
for(int t=0;t<4;t++)
Maze[t][j]++;
Maze[i][j]--;
}
void set()
{
char ch;min_step=0;
memset(Maze,0,sizeof(Maze));
for(i=0;i<4;i++)
{
for(j=0;j<4;j++)
{
cin>>ch;
if(ch=='+')
change(i,j);
}
}
}
void search()
{
for(i=0;i<4;i++)
for(j=0;j<4;j++)
{
min_step+=Maze[i][j]%2;
}
}
int main()
{
set();
search();
cout<<min_step<<endl;
for(i=0;i<4;i++)
for(j=0;j<4;j++)
{
if(Maze[i][j]%2==1)
cout<<i+1<<" "<<j+1<<endl;
}
system("pause");
return 0;
}