QOJ.ac

QOJ

ID题目提交者结果用时内存语言文件大小提交时间测评时间
#679761#7900. Gifts from KnowledgeRapidsRE 15ms3592kbC++204.7kb2024-10-26 18:27:262024-10-26 18:27:26

Judging History

你现在查看的是最新测评结果

  • [2024-10-26 18:27:26]
  • 评测
  • 测评结果:RE
  • 用时:15ms
  • 内存:3592kb
  • [2024-10-26 18:27:26]
  • 提交

answer

/*
    @file             G.cpp
    @author           1
    @date             2024-10-25 15:31
*/
#include <bits/stdc++.h>

using namespace std;
#define all(a) a.begin(), a.end()
#define pb push_back
#define eb emplace_back
#define IOS ios::sync_with_stdio(false); cin.tie(0); cout.tie(0)
#define endl '\n'

void print() { cout << '\n'; }

template<typename T, typename...Args>
void print(T t, Args...args) {
    cout << t << ' ';
    print(args...);
}

using pii = pair<int, int>;
using ll = long long;
using pll = pair<ll, ll>;
const int N = 2e5 + 10;
const int mod = 1000000000 + 7;
const ll MAX = 1e18;
// function

template<typename T>
void chmax(T &x, T y) { x = max(x, y); }

template<typename T>
void chmin(T &x, T y) { x = min(x, y); }

template<typename T = int>
vector<T> readVector(int n) {
    vector<T> a(n);
    for (T &x : a) cin >> x;
    return a;
}

void solve() {
    int r, c;
    cin >> r >> c;
    string s[r];
    for (int i = 0; i < r; ++i)
        cin >> s[i];
    //c = (int) s[0].size();
    for (int j = 0; j <= c / 2; ++j) {
        int cnt = 0;
        for (int i = 0; i < r; ++i) {
            cnt += s[i][j] == '1';
            if (j != c - j - 1) {
                cnt += s[i][c - j - 1] == '1';
            }
        }
        if (j == c - j - 1 && cnt > 1) {
            std::cout << 0 << '\n';
            return;
        } else if (cnt > 2) {
            std::cout << 0 << '\n';
            return;
        }
    }

    vector<int> num(c);
    for (int j = 0; j < c; j++) {
        for (int i = 0; i < r; i++) {
            num[j] += s[i][j] == '1';
        }
    }
    auto re = [&](string a) -> string {
        reverse(all(a));
        return a;
    };
    for (int j = 0; j < c; ++j) {
        if (num[j] > 1) {
            bool flag = false;
            vector<int> idx;
            for (int i = 0; i < r; ++i) {
                if (s[i][j] == '1') {
                    idx.push_back(i);
                }
            }
            string a = re(s[idx[0]]);
            auto tmp = num;
            for (int k = 0; k < c; k++) {
                tmp[k] += a[k] == '1';
                tmp[k] -= s[idx[0]][k] == '1';
                if (tmp[k] > 1) {
                    reverse(all(s[idx[1]]));
                    flag = true;
                    break;
                }
            }
            if (!flag) {
                reverse(all(s[idx[0]]));
            }
        }

    }

    // vector<bool> bl(r);
    // for (int j = 0; j < c; ++j) {
    //     bool b = true;
    //     int x = -1;
    //     for (int i = 0; i < r; ++i) {
    //         if (s[i][j] == '1') {
    //             if (b) {
    //                 b = false;
    //                 x = i;
    //             }
    //             else {
    //                 if (!bl[i]) {
    //                     reverse(all(s[i]));
    //                     bl[i] = true;
    //                 } else {
    //                     reverse(all(s[x]));
    //                     bl[x] = true;
    //                 }
    //                 break;
    //             }
    //         }
    //     }
    // }

    for (int j = 0; j < c; ++j) {
        int cnt = 0;
        for (int i = 0; i < r; ++i) {
            cnt += s[i][j] == '1';
        }
        if (cnt > 1) {
            std::cout << 0 << '\n';
            return;
        }
    }


    /*for (int i = 0; i < r; ++i)
        cout << s[i] << endl;*/

    int p[r + 1];
// p 寻找根节点,size 求数组包含的元素,仅根节点有效
    for (int i = 1; i <= r; ++i)
        p[i] = i; // 一开始各自在自己的集合

    function<int(int)> find = [&](int x) {
        if (p[x] != x)
            p[x] = find(p[x]);
        return p[x];
    };

    auto insert = [&](int x, int y) {
        if (find(x) != find(y))
            p[find(y)] = find(x);
    };

    for (int j = 0; j < c / 2; ++j) {
        vector<int> d;
        for (int i = 0; i < r; ++i) {
            if (s[i][j] == '1')
                d.pb(i + 1);
            if (s[i][c - j - 1] == '1')
                d.pb(i + 1);
        }
        for (int i = 1; i < d.size(); ++i)
            insert(d[i], d[i - 1]);
    }
    set<int> st;
    for (int i = 1; i <= r; ++i)
        st.insert(find(i));
    ll ans = 1;
    for (int i = 0; i < st.size(); ++i) {
        ans = (ans * 2) % mod;
        //cout << ans << ' ';
    }
    //cout << num << ' ';
    cout << ans << endl;
}

int main() {
    IOS;
    int t = 1;
    cin >> t;
    while (t--)
        solve();
    return 0;
}
/*
000000000001000
010000000000001
010100001000100
 */

詳細信息

Test #1:

score: 100
Accepted
time: 0ms
memory: 3592kb

input:

3
3 5
01100
10001
00010
2 1
1
1
2 3
001
001

output:

4
0
2

result:

ok 3 number(s): "4 0 2"

Test #2:

score: 0
Accepted
time: 15ms
memory: 3512kb

input:

15613
10 10
0000000000
0000000000
0000000000
0000000000
0000000000
0000000000
0000000000
0000000000
0000000000
0000000000
15 8
00000000
00000000
00000000
00000000
00000000
00000000
00000000
00000000
00000000
00000000
00000000
00000000
00000000
00000000
00000000
1 5
00000
5 9
000000000
000000000
0000...

output:

1024
32768
2
32
32768
128
32
16
16
2
16384
16384
128
128
32768
8192
128
64
16384
2
4
2
4096
16
4096
1024
32768
32768
16384
8
128
2
16
4096
8192
32768
8192
8192
16
16384
16384
256
128
8
256
8
4096
512
2
4
32
32
2
64
512
1024
32768
32768
2
64
16384
16
8192
16
256
16
64
8192
8192
64
1024
2
32768
2
4
51...

result:

ok 15613 numbers

Test #3:

score: -100
Runtime Error

input:

15759
9 6
000000
000000
000000
000000
000000
000000
000000
000000
000000
5 15
010000000000000
000000000000000
000000000000000
000100000000000
000100000000000
14 12
000000000000
000000000000
000000000000
000000000000
000000000000
000000000000
000000000000
000000000000
000000000000
000000000000
000000...

output:


result: