Submission #1023856

# Submission time Handle Problem Language Result Execution time Memory
1023856 2024-07-15T07:56:22 Z vjudge1 Wombats (IOI13_wombats) C++17
37 / 100
1263 ms 25044 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=111,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;
      |      ^~~
# Verdict Execution time Memory Grader output
1 Correct 96 ms 19548 KB Output is correct
2 Correct 95 ms 19548 KB Output is correct
3 Correct 130 ms 21248 KB Output is correct
4 Correct 95 ms 19544 KB Output is correct
5 Correct 95 ms 19544 KB Output is correct
6 Correct 4 ms 8536 KB Output is correct
7 Correct 3 ms 8540 KB Output is correct
8 Correct 4 ms 8540 KB Output is correct
# Verdict Execution time Memory Grader output
1 Correct 4 ms 8540 KB Output is correct
2 Correct 4 ms 8540 KB Output is correct
3 Correct 4 ms 8472 KB Output is correct
4 Correct 6 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 8540 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 8540 KB Output is correct
11 Correct 42 ms 9588 KB Output is correct
12 Correct 4 ms 8540 KB Output is correct
# Verdict Execution time Memory Grader output
1 Correct 263 ms 9052 KB Output is correct
2 Correct 254 ms 9052 KB Output is correct
3 Correct 264 ms 8908 KB Output is correct
4 Correct 265 ms 9052 KB Output is correct
5 Correct 259 ms 9048 KB Output is correct
6 Correct 4 ms 8540 KB Output is correct
7 Correct 3 ms 8540 KB Output is correct
8 Correct 4 ms 8540 KB Output is correct
9 Correct 1263 ms 9080 KB Output is correct
10 Correct 4 ms 8540 KB Output is correct
# Verdict Execution time Memory Grader output
1 Correct 97 ms 23600 KB Output is correct
2 Correct 97 ms 23660 KB Output is correct
3 Correct 97 ms 23640 KB Output is correct
4 Incorrect 129 ms 24944 KB Output isn't correct
5 Halted 0 ms 0 KB -
# Verdict Execution time Memory Grader output
1 Correct 269 ms 9060 KB Output is correct
2 Correct 256 ms 9052 KB Output is correct
3 Correct 270 ms 8796 KB Output is correct
4 Correct 265 ms 9052 KB Output is correct
5 Correct 262 ms 9056 KB Output is correct
6 Correct 97 ms 23388 KB Output is correct
7 Correct 97 ms 23652 KB Output is correct
8 Correct 95 ms 23640 KB Output is correct
9 Incorrect 116 ms 24916 KB Output isn't correct
10 Halted 0 ms 0 KB -
# Verdict Execution time Memory Grader output
1 Correct 264 ms 9048 KB Output is correct
2 Correct 267 ms 9052 KB Output is correct
3 Correct 255 ms 8792 KB Output is correct
4 Correct 266 ms 9064 KB Output is correct
5 Correct 262 ms 9056 KB Output is correct
6 Correct 97 ms 23384 KB Output is correct
7 Correct 99 ms 23640 KB Output is correct
8 Correct 95 ms 23644 KB Output is correct
9 Incorrect 116 ms 25044 KB Output isn't correct
10 Halted 0 ms 0 KB -