zoukankan      html  css  js  c++  java
  • CF1365A 题解

    Luogu-CF1365A

    题目分析

    如果当前玩家想要在网格图上找一个位置设置为 \(1\),条件式这一个位置所在的行以及列上都没有其它的 \(1\)

    观察到数据范围只有 $1 \leq n,m \leq 50 $,我们可以考虑直接在网格图上操作。

    在读入的时候,只要读入到当前位置的数为 \(1\),我们可以在网格图上将该行和该列上的所有数都标记为 \(1\)

    之后我们可以模拟玩家操作的过程,记录下当前回合谁在操作。每次遍历一遍网格图,如果发现网格图中有 \(0\),就把这个位置变为 \(1\),并且将该行和该列上的每一个数都变为 \(1\)

    以此不断循环,直到遍历网格图时没有 \(0\),就说明一个玩家要输了,此时输出当前不是谁在操作即可。

    代码

    #include <iostream>
    #include <cstdio>
    #include <cstring>
    #include <algorithm>
    #define ll long long
    using namespace std;
    
    ll n, T, m;
    bool a[100][100], ok = 0;
    
    void change(ll x, ll y){ 
        for (int i = 1; i <= n; ++i) a[i][y] = 1;
        for (int j = 1; j <= m; ++j) a[x][j] = 1;
    } //将该位置的每一行和每一列都该为1
    
    void CLEAR(){ 
        ok = 0;
        memset(a, 0, sizeof a);
    } //初始化
    
    int main()
    {
        T = read();
        while (T--)
        {
            CLEAR(); //初始化
            n = read(), m = read();
            for (int i = 1; i <= n; ++i){
                for (int j = 1; j <= m; ++j){
                    bool x;
                    cin >> x;
                    if (x == 1)
                        change(i, j); //修改
                }
            }
    
            while (1)
            {
                bool f = 0; //为遍历表之后没有找到0而弹出做准备
                for (int i = 1; i <= n; ++i){
                    for (int j = 1; j <= m; ++j){
                        if (a[i][j] == 0){
                            change(i, j);
                            if (ok == 0) ok = 1; //更换谁在操作
                            else ok = 0; //更换谁在操作
                            f = 1; //代表找到了0
                            break;
                        }
                    }
                    if (f == 1)
                        break;
                }
                if (f == 0){ //表里全是1,输出答案
                    if (ok == 0) puts("Vivek");
                    else puts("Ashish");
                    break;
                }
            }
        }
        return 0;
    }
    
  • 相关阅读:
    scott登录查询常用语句
    Oracle服务端及客户端安装
    SVN简单使用
    dos命令--查询进程
    第二周学习总结
    第一周学习总结
    虚拟机安装教程及网络连接方式的解释
    两天学习总结
    方差
    thinkphp 总结 转
  • 原文地址:https://www.cnblogs.com/EdisonBa/p/14702154.html
Copyright © 2011-2022 走看看