답안 #1023860

# 제출 시각 아이디 문제 언어 결과 실행 시간 메모리
1023860 2024-07-15T07:59:09 Z vjudge1 웜뱃 (IOI13_wombats) C++17
100 / 100
17390 ms 28352 KB
#include "wombats.h"
#include<bits/stdc++.h>
using namespace std;
int tmp[200][200],SSZZ;
int opt[201][201];
struct matrix{
    int V[200][200];
    void friend operator *=(matrix &a,matrix &b){
        memcpy(tmp,a.V,sizeof tmp);
        for(int i=0;i<SSZZ;i++)
            for(int j=0;j<SSZZ;j++)
                a.V[i][j]=1e9;
        for(int i=0;i<SSZZ;i++)
            opt[SSZZ][i]=SSZZ-1;
        for(int i=SSZZ;i--;) {
            for(int k=0;k<=opt[i+1][0];k++)
                if(a.V[i][0]>tmp[i][k]+b.V[k][0])
                    a.V[i][0]=tmp[i][k]+b.V[k][0],opt[i][0]=k;
            for(int j=1;j<SSZZ;j++)
                for(int k=opt[i][j-1];k<=opt[i+1][j];k++)
                    if(a.V[i][j]>tmp[i][k]+b.V[k][j])
                        a.V[i][j]=tmp[i][k]+b.V[k][j],opt[i][j]=k;
        }
    }
    void reset(){
        for(int i=0;i<200;i++)
            memset(V[i],15,sizeof V[i]),V[i][i]=0;
    }
} mygod[101],finalstuff;
int ans[200][200],lr[5000][200],dn[5000][200],col,row,SZ=310,blocknum;
void recalcblok(int blok){
    mygod[blok].reset();
    int end=min(row-1,SZ*blok+SZ);
    for(int r=SZ*blok+1;r<=end;r++){
        for(int i=0;i<col;i++) {
            for(int j=0;j<col;j++)
                mygod[blok].V[i][j]+=dn[r-1][j];
            for(int j=0;++j<col;)
                mygod[blok].V[i][j]=min(mygod[blok].V[i][j],
                        mygod[blok].V[i][j-1]+lr[r][j-1]);
            for(int j=col;--j;)
                mygod[blok].V[i][j-1]=min(mygod[blok].V[i][j-1],
                            mygod[blok].V[i][j]+lr[r][j-1]);
        }
    }
}
void redofinale(){
    int pref[200];
    pref[0]=0;
    for(int i=1;i<200;i++)
        pref[i]=pref[i-1]+lr[0][i-1];
    for(int i=0;i<col;i++) for(int j=0;j<col;j++)
        finalstuff.V[i][j]=abs(pref[i]-pref[j]);
    for(int i=0;i<=blocknum;i++)
        finalstuff*=mygod[i];
}
void init(int R, int C, int H[5000][200], int V[5000][200]) {
    SSZZ=C;
    for(int i=0;i<5000;i++)
        memcpy(lr[i],H[i],sizeof lr[i]),
        memcpy(dn[i],V[i],sizeof dn[i]);
    row=R;col=C;
    blocknum=(R-2)/SZ;
    for(int i=0;i<=blocknum;i++)
        recalcblok(i);
    redofinale();
}
void changeH(int P, int Q, int W) {
    lr[P][Q]=W;
    if(P)recalcblok(P/SZ),redofinale();
}

void changeV(int P, int Q, int W) {
    memset(ans,-1,sizeof ans);
    dn[P][Q]=W;
    recalcblok(P/SZ),redofinale();
}
int escape(int V1, int V2) {
    return finalstuff.V[V1][V2];
}

Compilation message

grader.c: In function 'int main()':
grader.c:15:6: warning: variable 'res' set but not used [-Wunused-but-set-variable]
   15 |  int res;
      |      ^~~
# 결과 실행 시간 메모리 Grader output
1 Correct 43 ms 14940 KB Output is correct
2 Correct 42 ms 14940 KB Output is correct
3 Correct 77 ms 16720 KB Output is correct
4 Correct 43 ms 14936 KB Output is correct
5 Correct 42 ms 14940 KB Output is correct
6 Correct 4 ms 8536 KB Output is correct
7 Correct 4 ms 8540 KB Output is correct
8 Correct 4 ms 8536 KB Output is correct
# 결과 실행 시간 메모리 Grader output
1 Correct 5 ms 8540 KB Output is correct
2 Correct 4 ms 8540 KB Output is correct
3 Correct 4 ms 8540 KB Output is correct
4 Correct 4 ms 8540 KB Output is correct
5 Correct 5 ms 8540 KB Output is correct
6 Correct 4 ms 8540 KB Output is correct
7 Correct 4 ms 8508 KB Output is correct
8 Correct 4 ms 8540 KB Output is correct
9 Correct 4 ms 8540 KB Output is correct
10 Correct 4 ms 8536 KB Output is correct
11 Correct 41 ms 9464 KB Output is correct
12 Correct 4 ms 8788 KB Output is correct
# 결과 실행 시간 메모리 Grader output
1 Correct 269 ms 9060 KB Output is correct
2 Correct 271 ms 9052 KB Output is correct
3 Correct 275 ms 8792 KB Output is correct
4 Correct 273 ms 9048 KB Output is correct
5 Correct 268 ms 9056 KB Output is correct
6 Correct 4 ms 8536 KB Output is correct
7 Correct 4 ms 8540 KB Output is correct
8 Correct 5 ms 8540 KB Output is correct
9 Correct 1248 ms 8992 KB Output is correct
10 Correct 4 ms 8540 KB Output is correct
# 결과 실행 시간 메모리 Grader output
1 Correct 47 ms 18912 KB Output is correct
2 Correct 46 ms 19032 KB Output is correct
3 Correct 48 ms 19036 KB Output is correct
4 Correct 65 ms 19796 KB Output is correct
# 결과 실행 시간 메모리 Grader output
1 Correct 265 ms 9048 KB Output is correct
2 Correct 250 ms 9060 KB Output is correct
3 Correct 262 ms 8904 KB Output is correct
4 Correct 269 ms 9072 KB Output is correct
5 Correct 275 ms 9048 KB Output is correct
6 Correct 46 ms 19056 KB Output is correct
7 Correct 47 ms 19036 KB Output is correct
8 Correct 46 ms 19036 KB Output is correct
9 Correct 65 ms 19796 KB Output is correct
10 Correct 42 ms 14936 KB Output is correct
11 Correct 44 ms 14936 KB Output is correct
12 Correct 77 ms 16708 KB Output is correct
13 Correct 43 ms 14940 KB Output is correct
14 Correct 43 ms 14940 KB Output is correct
15 Correct 4 ms 8540 KB Output is correct
16 Correct 4 ms 8540 KB Output is correct
17 Correct 4 ms 8540 KB Output is correct
18 Correct 4 ms 8516 KB Output is correct
19 Correct 4 ms 8536 KB Output is correct
20 Correct 4 ms 8540 KB Output is correct
21 Correct 4 ms 8540 KB Output is correct
22 Correct 4 ms 8540 KB Output is correct
23 Correct 4 ms 8540 KB Output is correct
24 Correct 5 ms 8540 KB Output is correct
25 Correct 44 ms 9556 KB Output is correct
26 Correct 4 ms 8540 KB Output is correct
27 Correct 1244 ms 9056 KB Output is correct
28 Correct 4363 ms 19396 KB Output is correct
29 Correct 4443 ms 21184 KB Output is correct
30 Correct 4046 ms 21172 KB Output is correct
31 Correct 4487 ms 24916 KB Output is correct
32 Correct 4 ms 8540 KB Output is correct
# 결과 실행 시간 메모리 Grader output
1 Correct 270 ms 9052 KB Output is correct
2 Correct 272 ms 9056 KB Output is correct
3 Correct 257 ms 8904 KB Output is correct
4 Correct 278 ms 9052 KB Output is correct
5 Correct 272 ms 9048 KB Output is correct
6 Correct 46 ms 19032 KB Output is correct
7 Correct 51 ms 19076 KB Output is correct
8 Correct 49 ms 19032 KB Output is correct
9 Correct 65 ms 19792 KB Output is correct
10 Correct 44 ms 14936 KB Output is correct
11 Correct 43 ms 14940 KB Output is correct
12 Correct 76 ms 16704 KB Output is correct
13 Correct 43 ms 14940 KB Output is correct
14 Correct 44 ms 14940 KB Output is correct
15 Correct 719 ms 19284 KB Output is correct
16 Correct 16681 ms 20932 KB Output is correct
17 Correct 4 ms 8536 KB Output is correct
18 Correct 4 ms 8540 KB Output is correct
19 Correct 3 ms 8536 KB Output is correct
20 Correct 4 ms 8536 KB Output is correct
21 Correct 4 ms 8536 KB Output is correct
22 Correct 4 ms 8540 KB Output is correct
23 Correct 4 ms 8628 KB Output is correct
24 Correct 4 ms 8616 KB Output is correct
25 Correct 4 ms 8540 KB Output is correct
26 Correct 4 ms 8540 KB Output is correct
27 Correct 42 ms 9552 KB Output is correct
28 Correct 4 ms 8536 KB Output is correct
29 Correct 1248 ms 9056 KB Output is correct
30 Correct 4480 ms 19500 KB Output is correct
31 Correct 15919 ms 27732 KB Output is correct
32 Correct 17276 ms 27596 KB Output is correct
33 Correct 4425 ms 20980 KB Output is correct
34 Correct 17390 ms 25152 KB Output is correct
35 Correct 4309 ms 20948 KB Output is correct
36 Correct 15842 ms 25172 KB Output is correct
37 Correct 4889 ms 24976 KB Output is correct
38 Correct 17071 ms 28352 KB Output is correct
39 Correct 4 ms 8752 KB Output is correct
40 Correct 16488 ms 25400 KB Output is correct