poj2965

又是一道模拟题,采用枚举的方法就可

#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;
}


你可能感兴趣的:(search,System)