Submission #582175

# Submission time Handle Problem Language Result Execution time Memory
582175 2022-06-23T13:21:37 Z TimDee Colouring a rectangle (eJOI19_colouring) C++14
0 / 100
348 ms 6500 KB
#include <bits/stdc++.h>
using namespace std;

#define paiu return
#define moment 0;
 
#define int long long
#define ll long long
 
#define forn(i,x) for (int i=0; i<x; i++)
 
#define vi(a,n) vector<int> a(n,0)
 
//cringe define
#define vii(a,n) vi(a,n); forn(i,n) cin>>a[i];
vector<int> ___makeprefsum(vector<int>&a) {
    int n=a.size();
    vi(pr,n+1);
    forn(i,n) pr[i+1]=pr[i]+a[i];
    return pr;
}
#define prefsum(pr,a) vector<int> pr=___makeprefsum(a);

#define all(v) v.begin(),v.end()

#define rall(v) v.rbegin(),v.rend()
 
#define pb(x) push_back(x)
#define pf pop_front();
#define last(c) c[c.size()-1]
 
#define f first
#define s second
 
#define pi pair<int, int>
#define mp(x,y) make_pair(x, y)
 
const ll mod = 1000000007;
const double ppi = acos(0) * 2;
     
//const int maxn = 3e5+1;
const int inf = INT_MAX;
const ll linf = LLONG_MAX;
const ll mmod = 998244353;

struct node {

    int sz=0,cost=0;
    vector<vector<int>> a;

};

vector<node> v;
int n,m;

void bruteforce(vector<int>&a, vector<int>&b, node N, int i) {

    if (i==n+m-1+n+m-1) {
        v.pb(N);
        return;
    }

    bruteforce(a,b,N,i+1);
    if (i>=n+m-1) {
        //work with B
        N.cost+=b[i-n-m+1];
        if (i-n-m+1>=n) {
            //work with Bottom
            int y=i-n-m+1-n+1;
            int x=n-1;
            while (x>=0 && y<m) {
                N.sz+=1-N.a[x][y];
                N.a[x][y]=1;
                x--,y++;
            }
        } else {
            //work with Left
            int y=0;
            int x=i-n-m+1;
            while (x>=0 && y<m) {
                N.sz+=1-N.a[x][y];
                N.a[x][y]=1;
                x--,y++;
            }
        }
    } else {
        //work with A
        N.cost+=a[i];
        if (i<m) {
            //work with Top
            int y=m-1-i;
            int x=0;
            while (x<n && y<m) {
                N.sz+=1-N.a[x][y];
                N.a[x][y]=1;
                x++,y++;
            }
        } else {
            //work with Left
            int y=0;
            int x=i-m+1;
            while (x<n && y<m) {
                N.sz+=1-N.a[x][y];
                N.a[x][y]=1;
                x++,y++;
            }
        }
    }
    bruteforce(a,b,N,i+1);

}

void solve() {
    
    cin>>n>>m;

    //if (m==1) {
    //    //int ans=0;
    //    //vii(a,n);
    //    //vii(b,n);
    //    //forn(i,n) ans+=min(a[i],b[])
    //    //cout<<ans;
    //    //return;
    //    cout<<"ia liubliu apelsin\n";
    //    return;
    //}

    vii(md,m+n-1);
    vii(pd,m+n-1);

    if (n==1) {
        exit(1);
        unsigned ll raspuns=0;
        forn(I,n+m-1) {
            if (md[I] < pd[I]) raspuns+=md[I];
            else raspuns+=pd[I];
        }
        cout<<raspuns<<endl;
        return;
    }

    if (m+n-1>=20) exit(0);

    node zero;
    zero.a.resize(n);
    forn(i,n) zero.a[i].assign(m,0);
    bruteforce(md,pd,zero,0);
    int ans=linf;

    forn(i,v.size()) {

        //cout<<v[i].sz<<' '<<v[i].cost<<'\n';
        //forn(j,n) {
        //    forn(k,m) cout<<v[i].a[j][k]<<' ';
        //    cout<<'\n';
        //}
        //cout<<'\n';

    }

    forn(i,v.size()) if (v[i].sz==1ll*n*m) {
        if (ans>v[i].cost) {
            ans=v[i].cost;
            //forn(j,n) {
            //    forn(k,m) cout<<v[i].a[j][k]<<' ';
            //    cout<<'\n';
            //}
            //cout<<"! ";
            //forn(j,v[i].used.size()) cout<<v[i].used[j]<<' '; cout<<'\n';
            //cout<<'\n';
        }
    }
    cout<<ans;

}

int32_t main() {
    //ios_base::sync_with_stdio(0); cin.tie(0); cout.tie(0);

    //init_primes();
    
    int t=1;
    //cin>>t;
    
    while(t--) solve();
    
    paiu moment
}

Compilation message

colouring.cpp: In function 'void solve()':
colouring.cpp:10:34: warning: comparison of integer expressions of different signedness: 'long long int' and 'std::vector<node>::size_type' {aka 'long unsigned int'} [-Wsign-compare]
   10 | #define forn(i,x) for (int i=0; i<x; i++)
......
  150 |     forn(i,v.size()) {
      |          ~~~~~~~~~~               
colouring.cpp:150:5: note: in expansion of macro 'forn'
  150 |     forn(i,v.size()) {
      |     ^~~~
colouring.cpp:10:34: warning: comparison of integer expressions of different signedness: 'long long int' and 'std::vector<node>::size_type' {aka 'long unsigned int'} [-Wsign-compare]
   10 | #define forn(i,x) for (int i=0; i<x; i++)
......
  161 |     forn(i,v.size()) if (v[i].sz==1ll*n*m) {
      |          ~~~~~~~~~~               
colouring.cpp:161:5: note: in expansion of macro 'forn'
  161 |     forn(i,v.size()) if (v[i].sz==1ll*n*m) {
      |     ^~~~
# Verdict Execution time Memory Grader output
1 Correct 0 ms 212 KB Output is correct
2 Correct 3 ms 1364 KB Output is correct
3 Correct 11 ms 5784 KB Output is correct
4 Correct 1 ms 340 KB Output is correct
5 Correct 1 ms 468 KB Output is correct
6 Correct 3 ms 1364 KB Output is correct
7 Correct 11 ms 5788 KB Output is correct
8 Correct 1 ms 468 KB Output is correct
9 Correct 11 ms 5740 KB Output is correct
10 Runtime error 0 ms 212 KB Execution failed because the return code was nonzero
11 Halted 0 ms 0 KB -
# Verdict Execution time Memory Grader output
1 Correct 0 ms 212 KB Output is correct
2 Correct 3 ms 1364 KB Output is correct
3 Correct 11 ms 5784 KB Output is correct
4 Correct 1 ms 340 KB Output is correct
5 Correct 1 ms 468 KB Output is correct
6 Correct 3 ms 1364 KB Output is correct
7 Correct 11 ms 5788 KB Output is correct
8 Correct 1 ms 468 KB Output is correct
9 Correct 11 ms 5740 KB Output is correct
10 Runtime error 0 ms 212 KB Execution failed because the return code was nonzero
11 Halted 0 ms 0 KB -
# Verdict Execution time Memory Grader output
1 Correct 0 ms 212 KB Output is correct
2 Correct 3 ms 1364 KB Output is correct
3 Correct 11 ms 5784 KB Output is correct
4 Correct 1 ms 340 KB Output is correct
5 Correct 1 ms 468 KB Output is correct
6 Correct 3 ms 1364 KB Output is correct
7 Correct 11 ms 5788 KB Output is correct
8 Correct 1 ms 468 KB Output is correct
9 Correct 11 ms 5740 KB Output is correct
10 Runtime error 0 ms 212 KB Execution failed because the return code was nonzero
11 Halted 0 ms 0 KB -
# Verdict Execution time Memory Grader output
1 Correct 0 ms 212 KB Output is correct
2 Correct 3 ms 1364 KB Output is correct
3 Correct 11 ms 5784 KB Output is correct
4 Correct 1 ms 340 KB Output is correct
5 Correct 1 ms 468 KB Output is correct
6 Correct 3 ms 1364 KB Output is correct
7 Correct 11 ms 5788 KB Output is correct
8 Correct 1 ms 468 KB Output is correct
9 Correct 11 ms 5740 KB Output is correct
10 Runtime error 0 ms 212 KB Execution failed because the return code was nonzero
11 Halted 0 ms 0 KB -
# Verdict Execution time Memory Grader output
1 Runtime error 146 ms 3388 KB Execution failed because the return code was nonzero
2 Halted 0 ms 0 KB -
# Verdict Execution time Memory Grader output
1 Incorrect 348 ms 6500 KB Output isn't correct
2 Halted 0 ms 0 KB -
# Verdict Execution time Memory Grader output
1 Correct 0 ms 212 KB Output is correct
2 Correct 3 ms 1364 KB Output is correct
3 Correct 11 ms 5784 KB Output is correct
4 Correct 1 ms 340 KB Output is correct
5 Correct 1 ms 468 KB Output is correct
6 Correct 3 ms 1364 KB Output is correct
7 Correct 11 ms 5788 KB Output is correct
8 Correct 1 ms 468 KB Output is correct
9 Correct 11 ms 5740 KB Output is correct
10 Runtime error 0 ms 212 KB Execution failed because the return code was nonzero
11 Halted 0 ms 0 KB -