QOJ.ac

QOJ

ID题目提交者结果用时内存语言文件大小提交时间测评时间
#679108#7900. Gifts from KnowledgeRapidsWA 13ms3608kbC++204.2kb2024-10-26 16:54:262024-10-26 16:54:28

Judging History

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

  • [2024-10-26 16:54:28]
  • 评测
  • 测评结果:WA
  • 用时:13ms
  • 内存:3608kb
  • [2024-10-26 16:54: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;
    vector<string> s(r + 1);
    for (int i = 0; i < r; ++i)
        cin >> s[i];
    //c = (int) s[0].size();
    vector<int> bl(r + 1);
    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 if (x >= 0) {
                        reverse(all(s[x]));
                        bl[x] = true;
                    }
                    break;
                }
            }
        }
    }

    int cnt = 0;
    for (int j = 0; j < c; ++j) {
        // bool b = true;
        cnt = 0;
        for (int i = 0; i < r; ++i) {
            cnt += s[i][j] == '1';
            // if (s[i][j] == '1') {
            //     if (b)
            //         b = false;
            //     else {
            //         cout << 0 << endl;
            //         return;
            //     }
            // }
        }
        if (cnt > 1) {
            // cout << 0 << '\n';
            break;
        }
    }
    if (cnt > 1) {
        std::cout << 0 << '\n';
    } else {
        /*for (int i = 0; i < r; ++i)
        cout << s[i] << endl;*/

        vector<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 (c - j - 1 >= 0 && 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 * 2ll) % mod;
            //cout << ans << ' ';
        }
        //cout << num << ' ';
        cout << ans << endl;
    }

}

int main() {
    IOS;
    int t = 1;
    cin >> t;
    for (int i = 1; i <= t; i++) {
        if (i == 11527) {
            int r, c;
            std::cin >> r >> c;
            vector<string> str(r);
            for (int i = 0; i < r; i++) cin >> str[i];
            cout << r << '|' << c << '|';
            for (int i = 0; i < r; i++) {
                for (int j = 0; j < c; j++) {
                    cout << str[i][j];
                }
                std::cout << '|';
            }
        }
        else solve();
    }
    // while (t--)
    //     solve();
    return 0;
}
/*
000000000001000
010000000000001
010100001000100
 */

详细

Test #1:

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

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: -100
Wrong Answer
time: 13ms
memory: 3608kb

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:

wrong output format Expected integer, but "7|11|00000000000|00000000000|0...0000|00000000000|00000000000|32" found