Codeforces Round #648 (Div. 2) A. Matrix Game

题目链接:https://codeforces.com/contest/1365/problem/A

题意

给出一个 $n \times m$ 的网格,两人轮流选择一个所在行列没有 $1$ 的方块置为 $1$,判断最后谁会胜利。

题解

模拟一共能走多少步,奇数先手胜,偶数后手胜。

代码

#include <bits/stdc++.h>
using namespace std;

void solve() {
    int n, m; cin >> n >> m;
    bool row[n] = {};
    bool col[m] = {};
    for (int i = 0; i < n; i++) {
        for (int j = 0; j < m; j++) {
            int x; cin >> x;
            if (x == 1) 
                row[i] = col[j] = true;
        }
    }
    int cnt = 0;
    for (int i = 0; i < n; i++) {
        for (int j = 0; j < m; j++) {
            if (!row[i] and !col[j]) {
                row[i] = col[j] = true;
                ++cnt;
            }
        }
    }
    cout << (cnt & 1 ? "Ashish" : "Vivek") << "\n";
}

int main() {
    int t; cin >> t;
    while (t--) solve();
}

 

posted @ 2020-06-08 01:05  Kanoon  阅读(138)  评论(0编辑  收藏  举报