首页 > 其他 > 详细

uva11464 Even Parity

时间:2018-10-27 14:24:00      阅读:130      评论:0      收藏:0      [点我收藏+]

白书第一章例题7

很套路了。枚举第一行,可以直接算出之后的几行。

#include <iostream>
using namespace std;
#include <stdio.h>
#include <cstring>
#define INF 10000000
int grid[20][20];
int temp[20][20];
int N;

int check(int k) {
    memset(temp,0,sizeof(temp));
    int sum = 0;
    for(int i = 0 ; i < N; i++){
        if(k & (1 << i))  temp[0][i] = 1;
        else if(grid[0][i] == 1) return INF;
        }
        for(int i = 1; i < N; i++) {
            for(int j = 0; j < N; j++) {
                sum = 0;
                if(i > 1) sum += temp[i - 2][j];
                if(j > 0) sum += temp[i - 1][j - 1];
                if(j < N - 1) sum += temp[i - 1][j + 1];
                temp[i][j] = sum % 2;
                if(grid[i][j] == 1 && temp[i][j] == 0) return INF;
            }
        }
        int cnt = 0;
        for(int i = 0 ; i <N; i++)
            for(int j = 0 ; j < N; j++) {
                if(temp[i][j] != grid[i][j])
                    cnt++;
            }
        return cnt;
}
int main() {
    int T,cases = 1;
    scanf("%d",&T);
    while(T--){
        scanf("%d",&N);
        for(int i = 0; i < N ; i++) {
            for(int j = 0; j < N; j++) {
                scanf("%d",&grid[i][j]);
            }
        }
        int ans = INF;
        for(int i = 0 ; i < (1 << N); i++) {
            ans = min(ans,check(i));
        }
        printf("Case %d: ",cases++);
        if(ans == INF) printf("-1\n");
        else printf("%d\n",ans);
    }
    return 0;
}

 

uva11464 Even Parity

原文:https://www.cnblogs.com/lqerio/p/9860917.html

(0)
(0)
   
举报
评论 一句话评论(0
关于我们 - 联系我们 - 留言反馈 - 联系我们:wmxa8@hotmail.com
© 2014 bubuko.com 版权所有
打开技术之扣,分享程序人生!