QOJ.ac

QOJ

ID题目提交者结果用时内存语言文件大小提交时间测评时间
#741089#7995. 图MiniLongAC ✓330ms8512kbC++203.3kb2024-11-13 13:18:082024-11-13 13:18:08

Judging History

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

  • [2024-11-13 13:18:08]
  • 评测
  • 测评结果:AC
  • 用时:330ms
  • 内存:8512kb
  • [2024-11-13 13:18:08]
  • 提交

answer

#include <bits/stdc++.h>
#define _rep(i, x, y) for(int i = x; i <= y; ++i)
#define _req(i, x, y) for(int i = x; i >= y; --i)
#define _rev(i, u) for(int i = head[u]; i; i = e[i].nxt)
#define pb push_back
#define fi first
#define se second
#define mst(f, i) memset(f, i, sizeof f)
using namespace std;
#ifdef ONLINE_JUDGE
#define debug(...) 0
#else
#define debug(...) fprintf(stderr, __VA_ARGS__), fflush(stderr)
#endif
typedef long long ll;
typedef pair<int, int> PII;
namespace fastio{
    #ifdef ONLINE_JUDGE
    char ibuf[1 << 20],*p1 = ibuf, *p2 = ibuf;
    #define get() p1 == p2 && (p2 = (p1 = ibuf) + fread(ibuf, 1, 1 << 20, stdin), p1 == p2) ? EOF : *p1++
    #else
    #define get() getchar()
    #endif
    template<typename T> inline void read(T &t){
        T x = 0, f = 1;
        char c = getchar();
        while(!isdigit(c)){
            if(c == '-') f = -f;
            c = getchar();
        }
        while(isdigit(c)) x = x * 10 + c - '0', c = getchar();
        t = x * f;
    }
    template<typename T, typename ... Args> inline void read(T &t, Args&... args){
        read(t);
        read(args...);
    }
    template<typename T> void write(T t){
        if(t < 0) putchar('-'), t = -t;
        if(t >= 10) write(t / 10);
        putchar(t % 10 + '0');
    }
    template<typename T, typename ... Args> void write(T t, Args... args){
        write(t), putchar(' '), write(args...);
    }
    template<typename T> void writeln(T t){
        write(t);
        puts("");
    }
    template<typename T> void writes(T t){
        write(t), putchar(' ');
    }
    #undef get
};
using namespace fastio;
#define multitest() int T; read(T); _rep(tCase, 1, T)
namespace Calculation{
    const ll mod = 998244353;
    ll ksm(ll p, ll h){ll base = p % mod, res = 1; while(h){if(h & 1ll) res = res * base % mod; base = base * base % mod, h >>= 1ll;} return res;}
    void dec(ll &x, ll y){x = ((x - y) % mod + mod) % mod;}
    void add(ll &x, ll y){x = (x + y) % mod;}
    void mul(ll &x, ll y){x = x * y % mod;}
    ll sub(ll x, ll y){return ((x - y) % mod + mod) % mod;}
    ll pls(ll x, ll y){return ((x + y) % mod + mod) % mod;}
    ll mult(ll x, ll y){return x * y % mod;}
}
using namespace Calculation;
const int N = 505;
int n, f[N][N], a[N][N], vis[N], in[N];
vector<int> G[N];
void work(int rt){
    _rep(i, 1, n) _rep(j, 1, n) if(i != j && f[rt][i] + a[i][j] == f[rt][j]) G[i].pb(j), in[j]++;
    queue<int> q; _rep(i, 1, n) if(!in[i]) q.push(i), vis[i] = 1;
    while(q.size()){
        int u = q.front(); q.pop();
        for(auto &v : G[u]){
            vis[v] = min(2, vis[v] + vis[u]);
            if(!--in[v]) q.push(v);
        }
    }
    _rep(i, 1, n) G[i].clear(), in[i] = 0;
}
int ans[N][N];
int main(){
    read(n);
    _rep(i, 1, n) _rep(j, 1, n) read(f[i][j]), a[i][j] = f[i][j];
    _rep(k, 1, n) _rep(i, 1, n) _rep(j, 1, n) f[i][j] = min(f[i][j], f[i][k] + f[k][j]);
    // _rep(i, 1, n){
    //     _rep(j, 1, n) debug("%d ", f[i][j]);
    //     debug("\n");
    // }
    _rep(i, 1, n){
        work(i);
        _rep(j, 1, n) if(i != j) ans[i][j] = f[i][j] == a[i][j] && vis[j] == 1;
        _rep(j, 1, n) vis[j] = 0;
    }
    _rep(i, 1, n){
        _rep(j, 1, n) write(ans[i][j]);
        puts("");
    }
    return 0;
}

详细

Test #1:

score: 100
Accepted
time: 1ms
memory: 5648kb

input:

4
0 3 2 100
3 0 8 100
2 8 0 10
100 100 10 0

output:

0110
1000
1001
0010

result:

ok 4 lines

Test #2:

score: 0
Accepted
time: 1ms
memory: 5572kb

input:

4
0 3 2 100
3 0 8 100
2 8 0 10
100 100 10 0

output:

0110
1000
1001
0010

result:

ok 4 lines

Test #3:

score: 0
Accepted
time: 3ms
memory: 5912kb

input:

100
0 41659 61282 49636 67326 48035 29694 46438 87384 82143 38685 66540 48746 29800 91786 54931 56232 61941 53423 75707 45135 69244 53802 89998 64199 63778 75825 31745 66975 44537 35793 55663 72647 60768 80884 46657 54066 84568 6266 48213 78216 50369 66761 54861 67607 38509 52250 54210 71135 56840 5...

output:

0000000000000000000000000000000000000010000100000000100001001000000000000001000000000000000000000010
0011000000100000000000000000000000000000000000000000000000100000000000000000000000000000000000000000
01001000010000000000000000000000000000000000000000001000000010000000000010000000010000000000000000...

result:

ok 100 lines

Test #4:

score: 0
Accepted
time: 3ms
memory: 5828kb

input:

100
0 81722 50546 79959 47292 51747 54712 7396 58005 52529 61319 66453 61823 76359 55454 60837 29465 61066 66711 75051 58395 38189 44176 32315 39742 46514 23229 27872 59119 39600 81204 45383 59424 40396 51094 74411 16551 30485 42587 18676 82697 76869 48206 41961 44633 59558 41795 57384 59943 18175 4...

output:

0000000100000000000000000000000000000000000000000100000000000001000000000000000100000000000000000000
0000000000000001010100000000000000000000000000000000000100000000001000000000000000000000000000000000
00000000001000001000000000001000000000000000000000000000000000000000100000001000000001000000000000...

result:

ok 100 lines

Test #5:

score: 0
Accepted
time: 4ms
memory: 6036kb

input:

100
0 1 2 1 2 1 1 1 1 1 1 1 1 2 2 2 2 2 1 2 2 2 2 2 1 1 2 1 1 1 1 1 1 1 1 1 1 2 2 1 1 1 2 1 1 1 1 1 1 2 1 1 2 2 1 1 1 2 2 1 1 2 1 2 1 2 1 2 2 2 1 1 2 1 2 3 1 1 2 2 2 1 1 1 1 2 1 1 2 1 1 1 1 1 1 1 1 2 1 1
1 0 1 1 1 2 3 2 2 1 1 1 1 2 2 1 3 3 2 2 1 3 2 2 2 1 3 2 2 1 1 2 2 3 1 2 1 1 1 1 1 2 3 2 1 1 2 1 ...

output:

0101011111111000001000001101111111111001110111111011001110011010101000110100110001111011011111111011
1011100001111001000010000100011000101111100011010110000111101011101000010001010111011010111011101101
01000011010010010111101101101111110111110000101000101111100010110010011100110101101010100000110011...

result:

ok 100 lines

Test #6:

score: 0
Accepted
time: 4ms
memory: 6108kb

input:

100
0 2 2 1 2 2 2 2 1 2 2 2 1 1 2 1 2 1 2 2 2 3 2 2 2 2 1 1 1 2 1 2 1 2 1 2 1 2 2 2 2 1 1 1 1 1 1 2 2 2 1 1 2 2 2 1 2 2 1 1 3 1 1 2 2 2 2 1 2 1 3 2 1 2 1 1 1 1 2 2 1 1 1 2 2 2 1 2 2 1 1 2 1 1 3 1 1 3 2 1
2 0 1 1 2 1 2 2 2 2 1 3 2 2 2 1 1 1 2 3 1 1 1 2 1 2 2 2 1 1 2 2 1 1 2 1 1 2 2 1 2 1 1 1 2 2 1 1 ...

output:

0001000010001101010000000011101010101000011111100011000100110110000101001011110011100010011011011001
0011010000100001110011101000110011011001011100110110101100010010000110100111100111111010101001011011
01010001110101001110100011100011010010110000110001110101101010111001101010110001101110011101010111...

result:

ok 100 lines

Test #7:

score: 0
Accepted
time: 176ms
memory: 6768kb

input:

500
0 743810 457854 85842 793418 318922 803556 939014 213357 346386 67230 841985 991820 600886 111369 198349 745203 809216 581207 443436 374000 684975 536767 444827 513284 841566 95714 870537 213411 507714 279089 852847 236477 266161 457883 432456 181558 6690 709759 89446 718063 263025 285303 124290...

output:

000000000000000000000000000000000000010000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000010000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000010000000000000000000000000000000000000000000000000000000000000...

result:

ok 500 lines

Test #8:

score: 0
Accepted
time: 185ms
memory: 6816kb

input:

500
0 2 2 8 1 5 10 7 6 9 5 9 2 4 8 6 5 3 1 3 3 10 7 1 7 9 10 9 6 6 9 2 8 9 10 10 1 5 5 9 6 5 8 8 6 5 6 2 3 3 10 10 8 4 10 9 6 6 6 6 2 9 6 5 4 3 7 8 6 1 6 4 1 9 5 8 9 2 7 6 8 1 1 8 7 7 4 3 5 10 4 1 8 1 6 9 6 6 10 8 8 10 1 10 4 9 2 4 5 5 4 4 8 1 3 8 8 4 1 8 1 8 3 8 2 6 2 4 9 2 10 7 9 1 10 9 7 1 4 1 9 ...

output:

000010000000000000100001000000000000100000000000000000000000000000000100100000000110000000010100000000100000000001000010100000000000010001010000100000000000000000000000000000010000000010000100000000101001000010000000000000010000100000000000000001100100000010000000000000010100000100000000000000000000...

result:

ok 500 lines

Test #9:

score: 0
Accepted
time: 178ms
memory: 7680kb

input:

500
0 14893 9715 8418 11689 7914 12453 6215 7449 8307 13288 8074 7145 7404 7035 6513 10885 7276 7395 9395 7329 6788 2571 11164 8363 6852 5689 3704 3170 13069 10644 6587 9992 8314 11542 8168 11649 8763 5142 7790 5867 5745 13489 9658 9898 6896 7174 4354 5776 9910 7437 6110 6612 4468 8756 2310 5397 982...

output:

000000000000000000000000000000000000000000000000000000000000000000000100000000000000000000000000000000000000010000000000000000000001000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000001010000000000000...

result:

ok 500 lines

Test #10:

score: 0
Accepted
time: 179ms
memory: 6672kb

input:

500
0 13216 9169 13904 1547 16781 11728 10087 14614 7941 15600 7706 20640 10377 12331 14186 9601 11270 13364 10161 10522 8487 11492 17192 12168 16538 9189 12061 10379 11223 9937 11564 6284 13004 7186 11204 14242 8111 6926 10945 12755 13084 4181 11593 11193 15592 15546 8845 9903 5180 14922 12151 9823...

output:

000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000001000000000000000000000000000000000000000000000000000000000000100000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000001000000...

result:

ok 500 lines

Test #11:

score: 0
Accepted
time: 330ms
memory: 8512kb

input:

500
0 1 1 1 1 2 1 1 1 2 1 2 1 1 1 1 1 1 1 1 1 1 2 2 1 2 1 1 1 2 1 1 1 2 2 2 1 2 1 2 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 2 1 1 1 2 1 1 2 1 1 2 2 1 1 1 1 1 1 1 1 1 2 1 1 1 1 1 1 2 2 1 1 1 2 1 1 1 1 2 1 1 2 1 1 2 1 1 1 1 1 2 1 1 1 1 2 1 1 1 1 1 1 1 1 2 1 2 1 1 1 1 1 1 1 2 1 1 1 1 1 2 1 1 1 1 1 1 1 1 1 1 1 2 ...

output:

011110111010111111111100101110111000101011111111111111101110110110011111111101111110011101111011011011111011110111111110101111111011111011111111111011010011111111111110111011010111110110111101111011110101111010111111011011111110101100110110111111110110001110111111111111011111010110111001111101110101...

result:

ok 500 lines

Test #12:

score: 0
Accepted
time: 328ms
memory: 7600kb

input:

500
0 1 1 1 2 1 2 1 1 1 2 1 1 1 1 1 1 1 1 1 2 1 2 1 1 2 1 1 1 1 2 1 2 1 1 1 2 2 1 1 1 1 1 2 1 1 1 1 1 1 1 1 2 1 1 1 1 1 1 1 1 1 1 1 2 2 1 1 2 1 2 1 1 1 2 1 1 1 1 1 1 1 1 1 1 1 1 1 2 1 2 1 1 1 1 1 1 1 1 2 2 1 1 1 2 2 1 1 1 1 1 2 1 1 2 1 1 1 1 2 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 2 1 1 1 1 1 1 1 2 1 ...

output:

011101011101111111110101101111010111001111101111111101111111111100110101110111111111111101011111111001110011111011011110111111111111111111011111110111011101010110000011111110001111100011101110111111111100010111111110110011001001011111111011111011001111111010001111001111111111111111101111011111111110...

result:

ok 500 lines

Test #13:

score: 0
Accepted
time: 1ms
memory: 5588kb

input:

10
0 102903 762919 272795 596098 162724 539281 422480 972306 801029
102903 0 785142 527821 728512 58732 284056 151031 254112 357952
762919 785142 0 553216 749299 508759 222588 86457 513574 786813
272795 527821 553216 0 87749 960681 437647 636732 130825 109597
596098 728512 749299 87749 0 724079 8275...

output:

0101000000
1000010110
0000001100
1000100011
0001000001
0100001001
0010010001
0110000010
0101000100
0001111000

result:

ok 10 lines

Test #14:

score: 0
Accepted
time: 1ms
memory: 5660kb

input:

10
0 7 9 4 3 4 2 9 8 2
7 0 8 7 2 10 5 7 2 6
9 8 0 7 2 5 2 9 1 8
4 7 7 0 4 8 3 4 6 5
3 2 2 4 0 5 9 7 7 10
4 10 5 8 5 0 6 1 3 4
2 5 2 3 9 6 0 1 3 10
9 7 9 4 7 1 1 0 1 7
8 2 1 6 7 3 3 1 0 5
2 6 8 5 10 4 10 7 5 0

output:

0001101001
0000100011
0000101010
1000101001
1111000000
0000000101
1011000100
0000011010
0110000101
1101010010

result:

ok 10 lines

Test #15:

score: 0
Accepted
time: 1ms
memory: 5576kb

input:

10
0 296685 168853 311204 319321 30372 128773 43837 288294 163351
296685 0 207992 462792 358459 276600 167911 290065 248089 233204
168853 207992 0 334959 230628 183722 40079 170258 324272 332204
311204 462792 334959 0 104331 280831 294880 267368 243671 395251
319321 358459 230628 104331 0 334191 190...

output:

0000011001
0000011011
0000001010
0000100110
0001001011
1100000110
1110100100
0001011000
0111110000
1100100000

result:

ok 10 lines

Test #16:

score: 0
Accepted
time: 1ms
memory: 5812kb

input:

10
0 255405 365136 78527 279299 184302 23569 393021 503455 96085
255405 0 109884 333933 258565 154113 278975 151345 262196 177107
365136 109884 0 396524 148679 263998 341567 41460 372081 286992
78527 333933 396524 0 301040 262831 54957 437986 424927 174612
279299 258565 148679 301040 0 271432 302869...

output:

0100011101
1010010011
0100101100
0000101010
0011000001
1100000001
1011000000
1010000000
0101000000
1100110000

result:

ok 10 lines

Test #17:

score: 0
Accepted
time: 1ms
memory: 5584kb

input:

10
0 2 2 1 4 2 5 2 3 4
2 0 1 1 4 1 4 3 4 2
2 1 0 1 4 2 5 4 3 3
1 1 1 0 3 1 3 4 2 4
4 4 4 3 0 4 7 1 7 7
2 1 2 1 4 0 2 4 3 5
5 4 5 3 7 2 0 8 1 4
2 3 4 4 1 4 8 0 6 6
3 4 3 2 7 3 1 6 0 3
4 2 3 4 7 5 4 6 3 0

output:

0001000100
0011010101
0101000000
1110110010
0001000100
0101001000
0000010010
1100100000
0001001001
0100000010

result:

ok 10 lines

Test #18:

score: 0
Accepted
time: 0ms
memory: 5692kb

input:

10
0 3 2 4 7 2 4 4 1 3
3 0 1 2 6 2 2 1 4 1
2 1 0 1 5 4 1 1 3 2
4 2 1 0 4 2 1 2 3 3
7 6 5 4 0 7 3 7 6 6
2 2 4 2 7 0 4 3 1 4
4 2 1 1 3 4 0 2 4 3
4 1 1 2 7 3 2 0 4 1
1 4 3 3 6 1 4 4 0 4
3 1 2 3 6 4 3 1 4 0

output:

0010000011
0010010101
1101001100
0010011000
0000001010
0101000010
0011100000
0110000001
1000110000
1100000100

result:

ok 10 lines

Test #19:

score: 0
Accepted
time: 0ms
memory: 5956kb

input:

100
0 865652 854605 909735 164494 414229 602669 428535 122877 919971 459811 724310 433010 360455 877866 96067 562884 361529 104991 178519 197425 853689 354804 504557 80597 524908 793930 230611 405083 883465 798550 471732 228873 85005 374026 829605 197037 680285 873452 342258 619169 800620 129491 671...

output:

0000000000000000000000000000000001000000000000000000000000000000000000000000010001000100000010000100
0000000000000000000000010000000000000000010000000000000010000000000011000010000000000000000000000000
00000010001000000000000000000000000000000000000000000000000100000000001000000000000000000000000000...

result:

ok 100 lines

Test #20:

score: 0
Accepted
time: 3ms
memory: 6048kb

input:

100
0 2 6 7 2 6 8 2 10 6 7 2 10 4 4 8 2 6 4 3 8 3 9 1 2 5 4 1 10 10 3 10 5 7 9 6 2 6 10 10 1 8 4 7 2 5 8 8 3 9 4 3 9 4 4 8 3 10 1 5 6 4 6 9 9 9 8 1 8 5 3 6 5 9 10 5 9 3 6 8 8 9 5 3 9 2 3 4 9 3 7 10 8 8 7 3 6 9 5 10
2 0 10 4 4 10 9 4 3 8 8 6 2 4 9 7 1 4 2 10 3 1 1 6 10 3 2 4 7 1 3 10 4 9 10 9 9 6 2 7...

output:

0000100100010000100000011001000000000000100000000000000000100000000100000000000000000100000000000000
0000000000000000101001100000010000000000100000000100000000000011111000000000000001000010000001001000
00000000000000001000010000100001010100000101000000000001000100000000011010000010000000000000000100...

result:

ok 100 lines