QOJ.ac

QOJ

ID题目提交者结果用时内存语言文件大小提交时间测评时间
#679704#7900. Gifts from KnowledgeRapidsWA 15ms3768kbC++203.6kb2024-10-26 18:11:412024-10-26 18:11:41

Judging History

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

  • [2024-10-26 18:11:41]
  • 评测
  • 测评结果:WA
  • 用时:15ms
  • 内存:3768kb
  • [2024-10-26 18:11:41]
  • 提交

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<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: 3768kb

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: 14ms
memory: 3496kb

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
Wrong Answer
time: 15ms
memory: 3496kb

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:

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

result:

wrong answer 11528th numbers differ - expected: '32', found: '0'