题意:
给你一个n*n的01矩阵,你的你的任务是吧尽量少的0变成1,使得每个元素的上下左右之和均为偶数(如果有的话),比如
0 0 0 0 1 0
1 0 0 ---> 1 0 1
0 0 0 0 1 0
是变换了3个。
思路:
这个题目拿到手的最暴力的反应就是直接搜索枚举所有,那么时间复杂度是
O(2^(15*15))直接就跪了,其实这个题目有个很关键的突破口,就是只要第一行确定了,那么其他的都是确定的,这个可以自己找几个矩阵试验下,所以我们可以直接深搜去枚举第一行,然后根据第一行吧所有的都填充完,看看有没有冲突,如果没有就更新答案的最优值,这样的时间复杂度是O(2^15*15*15) = O(32768 * 225)没啥大压力。
#include<stdio.h>
int map[16][16] ,now[16][16];
int Ans ,n;
void DFS(int noww)
{
if(noww == n + 1)
{
int tmp = 0;
for(int i = 1 ;i <= n ;i ++)
给你一个n*n的01矩阵,你的你的任务是吧尽量少的0变成1,使得每个元素的上下左右之和均为偶数(如果有的话),比如
0 0 0 0 1 0
1 0 0 ---> 1 0 1
0 0 0 0 1 0
是变换了3个。
思路:
这个题目拿到手的最暴力的反应就是直接搜索枚举所有,那么时间复杂度是
O(2^(15*15))直接就跪了,其实这个题目有个很关键的突破口,就是只要第一行确定了,那么其他的都是确定的,这个可以自己找几个矩阵试验下,所以我们可以直接深搜去枚举第一行,然后根据第一行吧所有的都填充完,看看有没有冲突,如果没有就更新答案的最优值,这样的时间复杂度是O(2^15*15*15) = O(32768 * 225)没啥大压力。
#include<stdio.h>
int map[16][16] ,now[16][16];
int Ans ,n;
void DFS(int noww)
{
if(noww == n + 1)
{
int tmp = 0;
for(int i = 1 ;i <= n ;i ++)