QOJ.ac

QOJ

ID题目提交者结果用时内存语言文件大小提交时间测评时间
#131331#6570. Who Watches the Watchmen?installbAC ✓2823ms26772kbC++147.0kb2023-07-26 22:40:172023-07-26 22:40:20

Judging History

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

  • [2023-08-10 23:21:45]
  • System Update: QOJ starts to keep a history of the judgings of all the submissions.
  • [2023-07-26 22:40:20]
  • 评测
  • 测评结果:AC
  • 用时:2823ms
  • 内存:26772kb
  • [2023-07-26 22:40:17]
  • 提交

answer

#include <bits/stdc++.h>
using namespace std;
typedef long long ll;

#define int long long

const int N = 2005;
const int M = 1000005;

int sgn(ll x){
    if(x > 0) return 1;
    if(x < 0) return -1;
    return 0;
}

struct point{
    int x,y,z; int id;
    point (int _x = 0,int _y = 0,int _z = 0) : x(_x), y(_y), z(_z) {}
}p[N],d[N],sp[N],q[N];

int n;

bool cmp(point p1,point p2){
    if(p1.x != p2.x) return p1.x < p2.x;
    if(p1.y != p2.y) return p1.y < p2.y;
    return p1.z < p2.z;
}

point simpl(const point &p){
    int x = abs(__gcd(p.x,__gcd(p.y,p.z)));
    return point(p.x / x,p.y / x,p.z / x);
}

point operator - (const point &p1,const point &p2){
    return point(p1.x - p2.x,p1.y - p2.y,p1.z - p2.z);
}

point operator + (const point &p1,const point &p2){
    return point(p1.x + p2.x,p1.y + p2.y,p1.z + p2.z);
}

point det(const point &p1,const point &p2){
    return point(p1.y * p2.z - p1.z * p2.y,p1.z * p2.x - p1.x * p2.z,p1.x * p2.y - p1.y * p2.x);
}

ll dot(const point &p1,const point &p2){
    return 1ll * p1.x * p2.x + 1ll * p1.y * p2.y + 1ll * p1.z * p2.z;
}

int len(const point &p){
    return abs(p.x) + abs(p.y) + abs(p.z);
}

bool operator == (const point &p1,const point &p2){
    return p1.x == p2.x && p1.y == p2.y && p1.z == p2.z;
}

bool operator != (const point &p1,const point &p2){
    return p1.x != p2.x || p1.y != p2.y || p1.z != p2.z;
}

bool eq(const point &p1,const point &p2){
    return simpl(p1) == simpl(p2) || simpl(p1) == point(0,0,0) - simpl(p2);
} // parallel

bool eq2(const point &p1,const point &p2){
    return simpl(p1) == simpl(p2);
} // same direction

bool chk(const point &p1,const point &p2,const point &p3){
    if(eq(p1,p2) || eq(p2,p3) || eq(p1,p3)) return 0;
    if(!eq2(det(p1,p2),det(p2,p3))) return 0;
    if(!eq2(det(p1,p2),det(p3,p1))) return 0;
    if(!eq2(det(p2,p3),det(p3,p1))) return 0;
    return 1;
}

void input(point &p){
    cin >> p.x >> p.y >> p.z;
}

int ec = 1,to[M << 1],nxt[M << 1],cap[M << 1],w[M << 1];
int hed[N];
void add_edge(int f,int t,int c,int d){
    ++ ec; to[ec] = t; nxt[ec] = hed[f]; hed[f] = ec; cap[ec] = c; w[ec] = d;
    ++ ec; to[ec] = f; nxt[ec] = hed[t]; hed[t] = ec; cap[ec] = 0; w[ec] = -d;
}

int dis[N],inq[N],flw[N],pre[N],prv[N];

const int INF = 0x3f3f3f3f;

int spfa(int s,int t){
    for(int i = 1;i <= t;i ++){
        dis[i] = INF; inq[i] = 0; flw[i] = 0;
    }
    prv[t] = -1;
    queue <int> q;
    q.push(s); inq[s] = 1; dis[s] = 0; flw[s] = INF;
    while(!q.empty()){
        int u = q.front(); q.pop();
        inq[u] = 0;
        for(int i = hed[u];i;i = nxt[i]){
            int v = to[i];
            if(dis[v] > dis[u] + w[i] && cap[i]){
                dis[v] = dis[u] + w[i];
                prv[v] = u;
                pre[v] = i;
                flw[v] = min(flw[u],cap[i]);
                if(!inq[v]){
                    q.push(v);
                    inq[v] = 1;
                }
            }
        }
    }
    return prv[t] != -1;
}

int mcf = 0,mxf = 0;
void mcmf(int s,int t){
    while(spfa(s,t)){
        mxf += flw[t];
        mcf += flw[t] * dis[t];
        int now = t;
        while(now != s){
            cap[pre[now]] -= flw[t];
            cap[pre[now] ^ 1] += flw[t];
            now = prv[now];
        }
    }
}

void solve(){
    cin >> n;
    for(int i = 1;i <= n;i ++){
        input(p[i]);
        input(d[i]);
        p[i].id = i;
    }
    if(n == 1){
        cout << -1 << '\n';
        return;
    }

    int S = n + n + 1;
    int T = S + 1;
    for(int i = 1;i <= n;i ++){
        point di = simpl(d[i]);
        for(int j = 1;j <= n;j ++) if(j != i) sp[j] = simpl(p[j] - p[i]);
        for(int j = 1;j <= n;j ++){
            if(i == j) continue;
            int fl = 0;
            for(int k = 1;k <= n;k ++){
                if(k == i || k == j) continue;
                if(sp[k] == sp[j] && len(p[k] - p[i]) < len(p[j] - p[i])){
                    fl = 1; break;
                }
            }
            if(!fl){
                if(sp[j] == di) add_edge(i,j + n,1,0);
                else add_edge(i,j + n,1,1);
            }
        }
        add_edge(S,i,1,0);
        add_edge(i + n,T,1,0);
    }
    mcmf(S,T);
    if(mxf == n){
        cout << mcf << '\n';
        return;
    }

    int del = 0;
    for(int id = 1;id <= n;id ++){
        int qc = 0;
        for(int i = 1;i <= n;i ++){
            if(i == id) continue;
            q[++ qc] = p[i];
        }
        sort(q + 1,q + 1 + qc,cmp);

        vector <int> tor(qc + 2),fromr(qc + 2),pre(qc + 2),suf(qc + 2);
        tor[0] = fromr[0] = 0;
        for(int i = 1;i < qc;i ++){
            tor[i] = tor[i - 1];
            fromr[i] = fromr[i - 1];
            if(eq2(d[q[i].id],q[i + 1] - q[i])) tor[i] ++;
            if(eq2(d[q[i + 1].id],q[i] - q[i + 1])) fromr[i] ++;
        }
        pre[0] = suf[qc + 1] = 0;
        for(int i = 2;i <= qc;i += 2){
            pre[i] = pre[i - 2];
            if(eq2(d[q[i - 1].id],q[i] - q[i - 1])) pre[i] ++;
            if(eq2(d[q[i].id],q[i - 1] - q[i])) pre[i] ++;
        }
        for(int i = qc - 1;i >= 1;i -= 2){
            suf[i] = suf[i + 2];
            if(eq2(d[q[i].id],q[i + 1] - q[i])) suf[i] ++;
            if(eq2(d[q[i + 1].id],q[i] - q[i + 1])) suf[i] ++;
        }

        for(int l = 1;l <= qc;l += 2){
            for(int r = qc;r >= l;r -= 2){
                int cur = 0,lrs = 0;
                lrs = pre[l - 1] + suf[r + 1];
                // id -> l -> r -> id, d[id], d[r], l->r(q[r] - q[l]) froms a triangle
                cur = tor[r - 1] - tor[l - 1];
                if(l != r && eq(d[id],q[r] - q[l]) && eq(d[q[r].id],q[r] - q[l])) cur += 0;
                else if((l != r && chk(d[id],q[r] - q[l],d[q[r].id]) && dot(det(q[r] - q[l],d[q[r].id]),d[id]) == 0) || (l == r && simpl(point(0,0,0) - d[q[l].id]) == simpl(d[id]))) cur += 2;
                else cur ++;
                del = max(del,cur + lrs);
                // cout << "LR " << id << ' ' << l << ' ' << r << ' ' << cur + lrs << endl;
                // id -> r -> l -> id
                cur = fromr[r - 1] - fromr[l - 1];
                if(l != r && eq(d[id],q[r] - q[l]) && eq(d[q[l].id],q[r] - q[l])) cur += 0;
                else if((l != r && chk(d[id],q[l] - q[r],d[q[l].id]) && dot(det(q[r] - q[l],d[q[l].id]),d[id]) == 0) || (l == r && simpl(point(0,0,0) - d[q[l].id]) == simpl(d[id]))) cur += 2;
                else cur ++;
                del = max(del,cur + lrs);
                // cout << "RL " << id << ' ' << l << ' ' << r << ' ' << cur + lrs << endl;
                // cout << d[q[l].id].x << ',' << d[q[l].id].y << ' ' << d[id].x << ',' << d[id].y << '(' << eq(d[q[l].id],d[id]) << ' ' << eq(d[q[r].id],d[id]) << ')' << tor[r - 1] - tor[l - 1] << ' ' << fromr[r - 1] - fromr[l - 1] << '\n';
            }
        }
    }
    cout << 1000 + n - del << '\n';
}

signed main(){
    ios::sync_with_stdio(false);
    solve();
    return 0;
}

詳細信息

Test #1:

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

input:

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

output:

1002

result:

ok single line: '1002'

Test #2:

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

input:

4
66 45 10 73 39 36
95 14 26 47 84 59
14 66 89 89 36 78
16 27 94 79 24 24

output:

4

result:

ok single line: '4'

Test #3:

score: 0
Accepted
time: 2ms
memory: 11752kb

input:

3
0 0 0 1 0 0
1 1 1 1 0 0
2 2 2 1 0 0

output:

1002

result:

ok single line: '1002'

Test #4:

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

input:

3
0 0 0 1 1 1
1 1 1 1 0 0
2 2 2 1 0 0

output:

1001

result:

ok single line: '1001'

Test #5:

score: 0
Accepted
time: 2ms
memory: 9892kb

input:

3
0 0 0 1 0 0
1 1 1 1 0 0
2 2 2 -1 -1 -1

output:

1001

result:

ok single line: '1001'

Test #6:

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

input:

3
0 0 0 1 0 0
1 1 1 1 2 2
2 2 2 -1 -1 -1

output:

1000

result:

ok single line: '1000'

Test #7:

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

input:

3
0 0 0 1 0 0
1 1 1 1 2 2
2 2 2 1 1 1

output:

1001

result:

ok single line: '1001'

Test #8:

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

input:

1
0 0 0 3 1 4

output:

-1

result:

ok single line: '-1'

Test #9:

score: 0
Accepted
time: 2ms
memory: 11808kb

input:

4
0 0 0 1 1 1
1 0 0 -1 0 0
1 1 1 0 -1 0
1 0 1 0 1 0

output:

1

result:

ok single line: '1'

Test #10:

score: 0
Accepted
time: 83ms
memory: 10048kb

input:

500
0 0 0 1 0 0
1 0 0 1 0 0
2 0 0 -1 0 0
3 0 0 1 0 0
4 0 0 1 0 0
5 0 0 1 0 0
6 0 0 1 0 0
7 0 0 1 0 0
8 0 0 1 0 0
9 0 0 1 0 0
10 0 0 -1 0 0
11 0 0 -1 0 0
12 0 0 1 0 0
13 0 0 -1 0 0
14 0 0 1 0 0
15 0 0 1 0 0
16 0 0 1 0 0
17 0 0 -1 0 0
18 0 0 -1 0 0
19 0 0 -1 0 0
20 0 0 -1 0 0
21 0 0 1 0 0
22 0 0 1 0 0...

output:

250

result:

ok single line: '250'

Test #11:

score: 0
Accepted
time: 89ms
memory: 9988kb

input:

500
0 0 0 0 1 0
0 1 0 0 1 0
0 2 0 0 -1 0
0 3 0 0 1 0
0 4 0 0 1 0
0 5 0 0 1 0
0 6 0 0 1 0
0 7 0 0 1 0
0 8 0 0 1 0
0 9 0 0 1 0
0 10 0 0 -1 0
0 11 0 0 -1 0
0 12 0 0 1 0
0 13 0 0 -1 0
0 14 0 0 1 0
0 15 0 0 1 0
0 16 0 0 1 0
0 17 0 0 -1 0
0 18 0 0 -1 0
0 19 0 0 -1 0
0 20 0 0 -1 0
0 21 0 0 1 0
0 22 0 0 1 0...

output:

250

result:

ok single line: '250'

Test #12:

score: 0
Accepted
time: 90ms
memory: 10048kb

input:

500
0 0 0 0 0 1
0 0 1 0 0 1
0 0 2 0 0 -1
0 0 3 0 0 1
0 0 4 0 0 1
0 0 5 0 0 1
0 0 6 0 0 1
0 0 7 0 0 1
0 0 8 0 0 1
0 0 9 0 0 1
0 0 10 0 0 -1
0 0 11 0 0 -1
0 0 12 0 0 1
0 0 13 0 0 -1
0 0 14 0 0 1
0 0 15 0 0 1
0 0 16 0 0 1
0 0 17 0 0 -1
0 0 18 0 0 -1
0 0 19 0 0 -1
0 0 20 0 0 -1
0 0 21 0 0 1
0 0 22 0 0 1...

output:

250

result:

ok single line: '250'

Test #13:

score: 0
Accepted
time: 2ms
memory: 9908kb

input:

5
1 0 0 1 -1 0
2 0 0 0 1 0
3 0 0 -1 0 0
4 0 0 -1 0 0
5 0 0 -1 0 0

output:

1000

result:

ok single line: '1000'

Test #14:

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

input:

5
1 0 0 1 0 0
2 0 0 1 0 0
3 0 0 1 0 0
4 0 0 0 1 0
5 0 0 -1 -1 0

output:

1000

result:

ok single line: '1000'

Test #15:

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

input:

6
0 1 0 1 0 0
0 2 0 0 2 0
0 3 0 0 3 0
0 4 0 0 4 0
0 5 0 0 5 0
0 6 0 0 6 0

output:

4

result:

ok single line: '4'

Test #16:

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

input:

9
1 0 0 1 0 0
2 0 0 1 0 0
3 0 0 1 0 0
0 1 0 0 1 0
0 2 0 0 1 0
0 3 0 0 1 0
0 0 1 0 0 1
0 0 2 0 0 1
0 0 3 0 0 1

output:

3

result:

ok single line: '3'

Test #17:

score: 0
Accepted
time: 1795ms
memory: 9996kb

input:

499
0 0 0 1 0 0
1 0 0 1 0 0
2 0 0 -1 0 0
3 0 0 1 0 0
4 0 0 1 0 0
5 0 0 1 0 0
6 0 0 1 0 0
7 0 0 1 0 0
8 0 0 1 0 0
9 0 0 1 0 0
10 0 0 -1 0 0
11 0 0 -1 0 0
12 0 0 1 0 0
13 0 0 -1 0 0
14 0 0 1 0 0
15 0 0 1 0 0
16 0 0 1 0 0
17 0 0 -1 0 0
18 0 0 -1 0 0
19 0 0 -1 0 0
20 0 0 -1 0 0
21 0 0 1 0 0
22 0 0 1 0 0...

output:

1220

result:

ok single line: '1220'

Test #18:

score: 0
Accepted
time: 2355ms
memory: 11940kb

input:

499
0 0 0 0 1 0
0 1 0 0 1 0
0 2 0 0 -1 0
0 3 0 0 1 0
0 4 0 0 1 0
0 5 0 0 1 0
0 6 0 0 1 0
0 7 0 0 1 0
0 8 0 0 1 0
0 9 0 0 1 0
0 10 0 0 -1 0
0 11 0 0 -1 0
0 12 0 0 1 0
0 13 0 0 -1 0
0 14 0 0 1 0
0 15 0 0 1 0
0 16 0 0 1 0
0 17 0 0 -1 0
0 18 0 0 -1 0
0 19 0 0 -1 0
0 20 0 0 -1 0
0 21 0 0 1 0
0 22 0 0 1 0...

output:

1220

result:

ok single line: '1220'

Test #19:

score: 0
Accepted
time: 2823ms
memory: 9996kb

input:

499
0 0 0 0 0 1
0 0 1 0 0 1
0 0 2 0 0 -1
0 0 3 0 0 1
0 0 4 0 0 1
0 0 5 0 0 1
0 0 6 0 0 1
0 0 7 0 0 1
0 0 8 0 0 1
0 0 9 0 0 1
0 0 10 0 0 -1
0 0 11 0 0 -1
0 0 12 0 0 1
0 0 13 0 0 -1
0 0 14 0 0 1
0 0 15 0 0 1
0 0 16 0 0 1
0 0 17 0 0 -1
0 0 18 0 0 -1
0 0 19 0 0 -1
0 0 20 0 0 -1
0 0 21 0 0 1
0 0 22 0 0 1...

output:

1220

result:

ok single line: '1220'

Test #20:

score: 0
Accepted
time: 2ms
memory: 9936kb

input:

5
0 0 0 0 -1 0
1 0 0 1 0 0
2 0 0 1 0 0
3 0 0 1 0 0
4 0 0 1 0 0

output:

1001

result:

ok single line: '1001'

Test #21:

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

input:

5
0 0 0 1 0 0
1 0 0 1 0 0
2 0 0 1 0 0
3 0 0 1 0 0
4 0 0 0 1 0

output:

1001

result:

ok single line: '1001'

Test #22:

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

input:

5
0 0 0 1 0 0
1 0 0 1 0 0
2 0 0 0 -1 0
3 0 0 1 0 0
4 0 0 -1 0 0

output:

1001

result:

ok single line: '1001'

Test #23:

score: 0
Accepted
time: 2ms
memory: 9900kb

input:

5
0 0 0 1 0 0
1 0 0 -1 0 0
2 0 0 1 0 0
3 0 0 0 -1 0
4 0 0 1 0 0

output:

1001

result:

ok single line: '1001'

Test #24:

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

input:

5
0 0 0 1 1 0
1 0 0 1 0 0
2 0 0 1 0 0
3 0 0 1 0 0
4 0 0 -1 -1 0

output:

1001

result:

ok single line: '1001'

Test #25:

score: 0
Accepted
time: 2ms
memory: 9936kb

input:

5
0 0 0 1 1 0
1 0 0 1 0 0
2 0 0 1 0 0
3 0 0 1 0 0
4 0 0 1 1 0

output:

1001

result:

ok single line: '1001'

Test #26:

score: 0
Accepted
time: 2ms
memory: 9900kb

input:

5
0 0 0 5 -1 0
1 0 0 1 0 0
2 0 0 1 0 0
3 0 0 1 0 0
4 0 0 1 -1 0

output:

1001

result:

ok single line: '1001'

Test #27:

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

input:

17
0 0 0 0 0 1
0 1 0 0 0 1
0 2 0 0 0 1
0 3 0 0 0 1
0 4 0 0 0 1
0 -1 0 0 0 1
0 -2 0 0 0 1
0 -3 0 0 0 1
0 -4 0 0 0 1
1 3 0 0 0 1
2 3 0 0 0 1
-1 3 0 0 0 1
-2 3 0 0 0 1
1 -3 0 0 0 1
2 -3 0 0 0 1
-1 -3 0 0 0 1
-2 -3 0 0 0 1

output:

17

result:

ok single line: '17'

Test #28:

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

input:

17
0 0 0 0 4 0
0 1 0 0 -1 0
0 2 0 0 -2 0
0 3 0 0 -3 0
0 4 0 0 -4 0
0 -1 0 0 1 0
0 -2 0 0 2 0
0 -3 0 0 3 0
0 -4 0 0 4 0
1 3 0 -1 -3 0
2 3 0 -1 -2 0
-1 3 0 1 -3 0
-2 3 0 2 -3 0
1 -3 0 -1 3 0
2 -3 0 -2 3 0
-1 -3 0 1 3 0
-2 -3 0 2 3 0

output:

10

result:

ok single line: '10'

Test #29:

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

input:

17
0 0 0 0 1 0
0 1 0 0 1 0
0 2 0 0 1 0
0 3 0 0 1 0
0 4 0 2 -1 0
0 -1 0 0 1 0
0 -2 0 0 1 0
0 -3 0 0 1 0
0 -4 0 0 1 0
1 3 0 -1 0 0
2 3 0 -1 0 0
-1 3 0 -1 0 0
-2 3 0 4 -6 0
1 -3 0 -1 0 0
2 -3 0 -1 0 0
-1 -3 0 -1 0 0
-2 -3 0 2 -1 0

output:

3

result:

ok single line: '3'

Test #30:

score: 0
Accepted
time: 2ms
memory: 9904kb

input:

5
0 0 0 1 1 1
0 0 1 0 0 1
0 0 2 0 0 1
0 0 3 0 0 1
0 0 4 0 -1 1

output:

1001

result:

ok single line: '1001'

Test #31:

score: 0
Accepted
time: 1498ms
memory: 26144kb

input:

500
-455212 958307 274912 -88656 390687 881409
-498879 -623821 322766 -916023 347922 541726
-594515 -554311 -413504 -881701 -506880 -144667
658945 -503396 791805 314816 -830920 -769486
-200847 845218 468338 -166468 -49854 -287877
-820402 914874 916800 258029 -210000 -296727
702016 -389491 -31529 -52...

output:

499

result:

ok single line: '499'

Test #32:

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

input:

3
1000000 -1 -1 -1000000 -999999 -999999
-1 1000000 -1 101 -101 0
100 999899 -1 999999 1000000 999999

output:

1000

result:

ok single line: '1000'

Test #33:

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

input:

3
1000000 -1 -1 1000000 999999 999999
-1 1000000 -1 101 -101 0
100 999899 -1 999999 1000000 999999

output:

1001

result:

ok single line: '1001'

Test #34:

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

input:

3
1000000 -1 -1 -1000000 -999999 -999999
-1 1000000 -1 101 -101 0
100 999899 -1 -999999 -1000000 -999999

output:

1001

result:

ok single line: '1001'

Test #35:

score: 0
Accepted
time: 2ms
memory: 9900kb

input:

3
1000000 -1 -1 1000000 999999 999999
-1 1000000 -1 101 -101 0
100 999899 -1 -999999 -1000000 -999999

output:

1001

result:

ok single line: '1001'

Test #36:

score: 0
Accepted
time: 2ms
memory: 9964kb

input:

3
10 -1 -1 -10 -9 -9
-1 10 -1 11 -11 0
21 -12 -1 9 10 9

output:

1000

result:

ok single line: '1000'

Test #37:

score: 0
Accepted
time: 2ms
memory: 9912kb

input:

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

output:

1000

result:

ok single line: '1000'

Test #38:

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

input:

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

output:

1000

result:

ok single line: '1000'

Test #39:

score: 0
Accepted
time: 2ms
memory: 9932kb

input:

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

output:

1000

result:

ok single line: '1000'

Test #40:

score: 0
Accepted
time: 2ms
memory: 11848kb

input:

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

output:

1000

result:

ok single line: '1000'

Test #41:

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

input:

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

output:

1000

result:

ok single line: '1000'

Test #42:

score: 0
Accepted
time: 2ms
memory: 9960kb

input:

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

output:

1000

result:

ok single line: '1000'

Test #43:

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

input:

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

output:

1000

result:

ok single line: '1000'

Test #44:

score: 0
Accepted
time: 2ms
memory: 9936kb

input:

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

output:

1000

result:

ok single line: '1000'

Test #45:

score: 0
Accepted
time: 2ms
memory: 10024kb

input:

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

output:

1000

result:

ok single line: '1000'

Test #46:

score: 0
Accepted
time: 2ms
memory: 9904kb

input:

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

output:

1000

result:

ok single line: '1000'

Test #47:

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

input:

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

output:

1000

result:

ok single line: '1000'

Test #48:

score: 0
Accepted
time: 2ms
memory: 9924kb

input:

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

output:

1000

result:

ok single line: '1000'

Test #49:

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

input:

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

output:

1000

result:

ok single line: '1000'

Test #50:

score: 0
Accepted
time: 2ms
memory: 9980kb

input:

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

output:

1000

result:

ok single line: '1000'

Test #51:

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

input:

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

output:

1000

result:

ok single line: '1000'

Test #52:

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

input:

27
-1000000 -1000000 -1000000 1000000 0 1000000
-1000000 -1000000 0 -1000000 0 1000000
-1000000 -1000000 1000000 -1000000 0 1000000
-1000000 0 -1000000 1000000 1000000 1000000
-1000000 0 0 0 -1000000 1000000
-1000000 0 1000000 1000000 -1000000 1000000
-1000000 1000000 -1000000 1000000 0 1000000
-100...

output:

17

result:

ok single line: '17'

Test #53:

score: 0
Accepted
time: 86ms
memory: 9988kb

input:

500
-999983 -999981 -999977 17 19 23
-999966 -999962 -999954 17 19 23
-999949 -999943 -999931 17 19 23
-999932 -999924 -999908 17 19 23
-999915 -999905 -999885 17 19 23
-999898 -999886 -999862 17 19 23
-999881 -999867 -999839 17 19 23
-999864 -999848 -999816 17 19 23
-999847 -999829 -999793 17 19 23...

output:

250

result:

ok single line: '250'

Test #54:

score: 0
Accepted
time: 85ms
memory: 10020kb

input:

500
999983 999981 999977 -17 -19 -23
999966 999962 999954 -17 -19 -23
999949 999943 999931 -17 -19 -23
999932 999924 999908 -17 -19 -23
999915 999905 999885 -17 -19 -23
999898 999886 999862 -17 -19 -23
999881 999867 999839 -17 -19 -23
999864 999848 999816 -17 -19 -23
999847 999829 999793 -17 -19 -23...

output:

250

result:

ok single line: '250'

Test #55:

score: 0
Accepted
time: 85ms
memory: 11904kb

input:

500
999686 -999841 999735 -314 159 -265
999372 -999682 999470 -314 159 -265
999058 -999523 999205 314 -159 265
998744 -999364 998940 -314 159 -265
998430 -999205 998675 -314 159 -265
998116 -999046 998410 -314 159 -265
997802 -998887 998145 -314 159 -265
997488 -998728 997880 -314 159 -265
997174 -9...

output:

250

result:

ok single line: '250'

Test #56:

score: 0
Accepted
time: 86ms
memory: 9980kb

input:

500
999900 -999800 999700 -100 200 -300
999800 -999600 999400 -100 200 -300
999700 -999400 999100 100 -200 300
999600 -999200 998800 -100 200 -300
999500 -999000 998500 -100 200 -300
999400 -998800 998200 -100 200 -300
999300 -998600 997900 -100 200 -300
999200 -998400 997600 -100 200 -300
999100 -9...

output:

250

result:

ok single line: '250'

Test #57:

score: 0
Accepted
time: 27ms
memory: 10052kb

input:

480
-2402 3028 3274 23 -29 -31
-79 99 143 23 -29 -31
3854 -4860 -5158 -23 29 31
1370 -1728 -1810 -23 29 31
-4127 5203 5599 23 -29 -31
-5461 6885 7397 23 -29 -31
2382 -3004 -3174 -23 29 31
-1965 2477 2685 23 -29 -31
2888 -3642 -3856 -23 29 31
-3782 4768 5134 23 -29 -31
1899 -2395 -2523 -23 29 31
59 -...

output:

122

result:

ok single line: '122'

Test #58:

score: 0
Accepted
time: 28ms
memory: 10000kb

input:

480
43422 13353 -25668 414 129 -256
1608 324 188 414 129 -256
-69186 -21735 43964 -414 -129 256
-24474 -7803 16316 -414 -129 256
74472 23028 -44868 414 129 -256
98484 30510 -59716 414 129 -256
-42690 -13479 27580 -414 -129 256
35556 10902 -20804 414 129 -256
-51798 -16317 33212 -414 -129 256
68262 2...

output:

123

result:

ok single line: '123'

Test #59:

score: 0
Accepted
time: 2ms
memory: 10016kb

input:

180
375 636 1057 -4 -8 -12
47 -20 73 4 8 12
331 548 925 -4 -8 -12
-29 -172 -155 4 8 12
-153 -420 -527 4 8 12
427 740 1213 -4 -8 -12
-173 -460 -587 4 8 12
-241 -596 -791 4 8 12
179 244 469 -4 -8 -12
159 204 409 -4 -8 -12
-161 -436 -551 4 8 12
399 684 1129 -4 -8 -12
223 332 601 -4 -8 -12
59 4 109 -4 -...

output:

42

result:

ok single line: '42'

Test #60:

score: 0
Accepted
time: 7ms
memory: 10004kb

input:

220
27 -85 15 12 8 4
927 515 315 -12 -8 -4
-93 -165 -25 12 8 4
1083 619 367 -12 -8 -4
39 -77 19 12 8 4
-1281 -957 -421 12 8 4
1143 659 387 -12 -8 -4
183 19 67 -12 -8 -4
1047 595 355 -12 -8 -4
567 275 195 -12 -8 -4
531 251 183 -12 -8 -4
-177 -221 -53 12 8 4
579 283 199 -12 -8 -4
-561 -477 -181 12 8 4...

output:

52

result:

ok single line: '52'

Test #61:

score: 0
Accepted
time: 2ms
memory: 9936kb

input:

60
-171 215 267 23 -29 -31
473 -597 -601 -23 29 31
312 -394 -384 -23 29 31
404 -510 -508 -23 29 31
197 -249 -229 -23 29 31
335 -423 -415 -23 29 31
-654 824 918 23 -29 -31
-493 621 701 23 -29 -31
565 -713 -725 -23 29 31
-217 273 329 23 -29 -31
-631 795 887 23 -29 -31
496 -626 -632 -23 29 31
-447 563 ...

output:

17

result:

ok single line: '17'

Test #62:

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

input:

3
-1 0 0 2 1 0
1 0 0 -2 1 0
3 0 0 -2 -1 0

output:

1001

result:

ok single line: '1001'

Test #63:

score: 0
Accepted
time: 2ms
memory: 9896kb

input:

5
0 0 0 0 1 0
10 0 0 -1 1 0
0 10 0 -1 -1 0
-10 0 0 1 -1 0
0 -10 0 1 1 0

output:

1

result:

ok single line: '1'

Test #64:

score: 0
Accepted
time: 2ms
memory: 9956kb

input:

5
0 2 0 0 1 0
10 0 0 -1 1 0
0 10 0 -1 -1 0
-10 0 0 1 -1 0
0 -10 0 1 1 0

output:

1

result:

ok single line: '1'

Test #65:

score: 0
Accepted
time: 1469ms
memory: 24720kb

input:

500
464689 -654475 874948 278641 -792884 186354
-798268 -885245 366579 415873 -814492 568386
548594 757214 459960 -318745 -320885 285634
-970144 68165 91372 -935576 -557281 -82177
-71496 697792 859229 603072 -751718 -629380
-391402 -320266 -691800 99295 771407 -415586
131176 -704350 628899 959024 80...

output:

500

result:

ok single line: '500'

Test #66:

score: 0
Accepted
time: 1461ms
memory: 24760kb

input:

500
660575 -715271 73415 436140 226362 12224
19467 916145 -662062 -510604 824283 454499
205202 -915814 -735123 -110822 -83586 808202
13120 -72969 106150 -211607 557293 169887
-5849 149098 -624091 831479 -195891 -854258
335561 -450902 467595 -612441 695943 -877490
-356999 -751820 -886079 499927 46503...

output:

500

result:

ok single line: '500'

Test #67:

score: 0
Accepted
time: 1422ms
memory: 26316kb

input:

500
-425261 857089 -722463 345227 -983886 -779314
873569 -40018 -490178 580005 -863510 -254613
-435240 -520380 84908 -513784 564739 330588
-932188 -477605 -347322 492032 -294079 477227
-72311 862368 -29594 -887377 -627667 -608677
-775504 -953650 8567 -11911 -162415 -485409
822275 -380961 773749 9387...

output:

500

result:

ok single line: '500'

Test #68:

score: 0
Accepted
time: 1524ms
memory: 25956kb

input:

500
-132886 502058 -877447 79042 35022 -322286
101780 -909854 172531 103616 -119015 -271777
289064 -256857 -663836 977205 -748931 -999133
-68650 848633 -3718 -874892 260143 -880264
399836 -18330 881394 -913991 761700 620864
642012 105194 -288186 637083 -765709 -480047
-818650 -112345 310067 -918378 ...

output:

500

result:

ok single line: '500'

Test #69:

score: 0
Accepted
time: 1522ms
memory: 26772kb

input:

500
-455212 958307 274912 -88656 390687 881409
-498879 -623821 322766 -916023 347922 541726
-594515 -554311 -413504 -881701 -506880 -144667
658945 -503396 791805 314816 -830920 -769486
-200847 845218 468338 -166468 -49854 -287877
-820402 914874 916800 258029 -210000 -296727
702016 -389491 -31529 -52...

output:

500

result:

ok single line: '500'