Submission #1169049

#TimeUsernameProblemLanguageResultExecution timeMemory
1169049bbartekJelly Flavours (IOI20_jelly)C++20
Compilation error
0 ms0 KiB
#include <bits/stdc++.h>
#include "jelly.h"

using namespace std;

typedef long long ll;
#define st first
#define nd second
#define pb push_back

const int maxn = 2003;

int dp[203][503][503];
int dp2[1003][1003];

int find_maximum_unique(int x, int y, vector<int> a, vector<int> b) {
	int n = a.size();
    
    bool bibj = 1,aibi = 1;

    for(int i=1;i<n;i++){
        if(b[i] != b[i-1])
            bibj = 0;
    }

    for(int i=0;i<n;i++){
        if(a[i] != b[i])
            aibi = 0;
    }

    if(y==0){
        int wyn = 0;
        vector<pair<int,int>> vect;
        for(int i=0;i<n;i++){
            vect.pb({a[i],b[i]});
        }
        sort(vect.begin(),vect.end());
        for(int i=0;i<n;i++){
            if(vect[i].nd == 0){
                wyn++;  
                continue;
            }
            if(vect[i].st > x)
                continue;
            x -= vect[i].st;
            wyn++;
        }
        return wyn;
    }

    if(bibj){
        int wartosc = b[0];
        int wyn = 0;
        sort(a.begin(),a.end());
        for(auto i : a){
            if(x >= i){
                wyn++;
                x-=i;
                continue;
            }
            if(y >= wartosc){
                wyn++;
                y -= wartosc;
                continue;
            }
            break;
        }
        return wyn;
    }

    if(aibi){
        sort(a.begin(),a.end());
        int wyn = 0,start;
        for(int i=0;i<n;i++){
            if(a[i] == 0){
                wyn++;
                start = i+1;
            }
        }
        for(int i=0;i<x;i++){
            for(int j=0;j<y;j++){
                if(dp2[i][j] == 0){
                    dp2[i][j] = start;
                }
                if(i + a[dp2[i][j] + 1 - 1] <= x){
                    dp2[i+a[dp2[i][j] + 1 - 1]] = max(dp2[i+a[dp2[i][j] + 1 - 1]],dp2[i][j]+1);
                }
                if(j + a[dp2[i][j] + 1 - 1] <= y){
                    dp2[j+a[dp2[i][j] + 1 - 1]] = max(dp2[j+a[dp2[i][j] + 1 - 1]],dp2[i][j]+1);
                }
            }
        }
        return dp2[x][y];
    }

    for(int i=1;i<=n;i++){
        for(int j=0;j<=x;j++){
            for(int k=0;k<=y;k++){      
                dp[i][j][k] = dp[i-1][j][k];
                if(j-a[i-1] >= 0)
                    dp[i][j][k] = max(dp[i][j][k],dp[i-1][j-a[i-1]][k]+1);
                if(k-b[i-1] >= 0)
                    dp[i][j][k] = max(dp[i][j][k],dp[i-1][j][k-b[i-1]]+1);
            }
        }
    }

	return dp[n][x][y];
}

Compilation message (stderr)

jelly.cpp: In function 'int find_maximum_unique(int, int, std::vector<int>, std::vector<int>)':
jelly.cpp:86:54: error: no matching function for call to 'max(int [1003], int)'
   86 |                     dp2[i+a[dp2[i][j] + 1 - 1]] = max(dp2[i+a[dp2[i][j] + 1 - 1]],dp2[i][j]+1);
      |                                                   ~~~^~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
In file included from /usr/include/c++/11/bits/specfun.h:45,
                 from /usr/include/c++/11/cmath:1935,
                 from /usr/include/x86_64-linux-gnu/c++/11/bits/stdc++.h:41,
                 from jelly.cpp:1:
/usr/include/c++/11/bits/stl_algobase.h:254:5: note: candidate: 'template<class _Tp> constexpr const _Tp& std::max(const _Tp&, const _Tp&)'
  254 |     max(const _Tp& __a, const _Tp& __b)
      |     ^~~
/usr/include/c++/11/bits/stl_algobase.h:254:5: note:   template argument deduction/substitution failed:
jelly.cpp:86:54: note:   deduced conflicting types for parameter 'const _Tp' ('int [1003]' and 'int')
   86 |                     dp2[i+a[dp2[i][j] + 1 - 1]] = max(dp2[i+a[dp2[i][j] + 1 - 1]],dp2[i][j]+1);
      |                                                   ~~~^~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
In file included from /usr/include/c++/11/bits/specfun.h:45,
                 from /usr/include/c++/11/cmath:1935,
                 from /usr/include/x86_64-linux-gnu/c++/11/bits/stdc++.h:41,
                 from jelly.cpp:1:
/usr/include/c++/11/bits/stl_algobase.h:300:5: note: candidate: 'template<class _Tp, class _Compare> constexpr const _Tp& std::max(const _Tp&, const _Tp&, _Compare)'
  300 |     max(const _Tp& __a, const _Tp& __b, _Compare __comp)
      |     ^~~
/usr/include/c++/11/bits/stl_algobase.h:300:5: note:   template argument deduction/substitution failed:
jelly.cpp:86:54: note:   deduced conflicting types for parameter 'const _Tp' ('int [1003]' and 'int')
   86 |                     dp2[i+a[dp2[i][j] + 1 - 1]] = max(dp2[i+a[dp2[i][j] + 1 - 1]],dp2[i][j]+1);
      |                                                   ~~~^~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
In file included from /usr/include/c++/11/string:52,
                 from /usr/include/c++/11/bits/locale_classes.h:40,
                 from /usr/include/c++/11/bits/ios_base.h:41,
                 from /usr/include/c++/11/ios:42,
                 from /usr/include/c++/11/istream:38,
                 from /usr/include/c++/11/sstream:38,
                 from /usr/include/c++/11/complex:45,
                 from /usr/include/c++/11/ccomplex:39,
                 from /usr/include/x86_64-linux-gnu/c++/11/bits/stdc++.h:54,
                 from jelly.cpp:1:
/usr/include/c++/11/bits/stl_algo.h:3461:5: note: candidate: 'template<class _Tp> constexpr _Tp std::max(std::initializer_list<_Tp>)'
 3461 |     max(initializer_list<_Tp> __l)
      |     ^~~
/usr/include/c++/11/bits/stl_algo.h:3461:5: note:   template argument deduction/substitution failed:
jelly.cpp:86:54: note:   mismatched types 'std::initializer_list<_Tp>' and 'int*'
   86 |                     dp2[i+a[dp2[i][j] + 1 - 1]] = max(dp2[i+a[dp2[i][j] + 1 - 1]],dp2[i][j]+1);
      |                                                   ~~~^~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
In file included from /usr/include/c++/11/string:52,
                 from /usr/include/c++/11/bits/locale_classes.h:40,
                 from /usr/include/c++/11/bits/ios_base.h:41,
                 from /usr/include/c++/11/ios:42,
                 from /usr/include/c++/11/istream:38,
                 from /usr/include/c++/11/sstream:38,
                 from /usr/include/c++/11/complex:45,
                 from /usr/include/c++/11/ccomplex:39,
                 from /usr/include/x86_64-linux-gnu/c++/11/bits/stdc++.h:54,
                 from jelly.cpp:1:
/usr/include/c++/11/bits/stl_algo.h:3467:5: note: candidate: 'template<class _Tp, class _Compare> constexpr _Tp std::max(std::initializer_list<_Tp>, _Compare)'
 3467 |     max(initializer_list<_Tp> __l, _Compare __comp)
      |     ^~~
/usr/include/c++/11/bits/stl_algo.h:3467:5: note:   template argument deduction/substitution failed:
jelly.cpp:86:54: note:   mismatched types 'std::initializer_list<_Tp>' and 'int*'
   86 |                     dp2[i+a[dp2[i][j] + 1 - 1]] = max(dp2[i+a[dp2[i][j] + 1 - 1]],dp2[i][j]+1);
      |                                                   ~~~^~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
jelly.cpp:89:54: error: no matching function for call to 'max(int [1003], int)'
   89 |                     dp2[j+a[dp2[i][j] + 1 - 1]] = max(dp2[j+a[dp2[i][j] + 1 - 1]],dp2[i][j]+1);
      |                                                   ~~~^~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
In file included from /usr/include/c++/11/bits/specfun.h:45,
                 from /usr/include/c++/11/cmath:1935,
                 from /usr/include/x86_64-linux-gnu/c++/11/bits/stdc++.h:41,
                 from jelly.cpp:1:
/usr/include/c++/11/bits/stl_algobase.h:254:5: note: candidate: 'template<class _Tp> constexpr const _Tp& std::max(const _Tp&, const _Tp&)'
  254 |     max(const _Tp& __a, const _Tp& __b)
      |     ^~~
/usr/include/c++/11/bits/stl_algobase.h:254:5: note:   template argument deduction/substitution failed:
jelly.cpp:89:54: note:   deduced conflicting types for parameter 'const _Tp' ('int [1003]' and 'int')
   89 |                     dp2[j+a[dp2[i][j] + 1 - 1]] = max(dp2[j+a[dp2[i][j] + 1 - 1]],dp2[i][j]+1);
      |                                                   ~~~^~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
In file included from /usr/include/c++/11/bits/specfun.h:45,
                 from /usr/include/c++/11/cmath:1935,
                 from /usr/include/x86_64-linux-gnu/c++/11/bits/stdc++.h:41,
                 from jelly.cpp:1:
/usr/include/c++/11/bits/stl_algobase.h:300:5: note: candidate: 'template<class _Tp, class _Compare> constexpr const _Tp& std::max(const _Tp&, const _Tp&, _Compare)'
  300 |     max(const _Tp& __a, const _Tp& __b, _Compare __comp)
      |     ^~~
/usr/include/c++/11/bits/stl_algobase.h:300:5: note:   template argument deduction/substitution failed:
jelly.cpp:89:54: note:   deduced conflicting types for parameter 'const _Tp' ('int [1003]' and 'int')
   89 |                     dp2[j+a[dp2[i][j] + 1 - 1]] = max(dp2[j+a[dp2[i][j] + 1 - 1]],dp2[i][j]+1);
      |                                                   ~~~^~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
In file included from /usr/include/c++/11/string:52,
                 from /usr/include/c++/11/bits/locale_classes.h:40,
                 from /usr/include/c++/11/bits/ios_base.h:41,
                 from /usr/include/c++/11/ios:42,
                 from /usr/include/c++/11/istream:38,
                 from /usr/include/c++/11/sstream:38,
                 from /usr/include/c++/11/complex:45,
                 from /usr/include/c++/11/ccomplex:39,
                 from /usr/include/x86_64-linux-gnu/c++/11/bits/stdc++.h:54,
                 from jelly.cpp:1:
/usr/include/c++/11/bits/stl_algo.h:3461:5: note: candidate: 'template<class _Tp> constexpr _Tp std::max(std::initializer_list<_Tp>)'
 3461 |     max(initializer_list<_Tp> __l)
      |     ^~~
/usr/include/c++/11/bits/stl_algo.h:3461:5: note:   template argument deduction/substitution failed:
jelly.cpp:89:54: note:   mismatched types 'std::initializer_list<_Tp>' and 'int*'
   89 |                     dp2[j+a[dp2[i][j] + 1 - 1]] = max(dp2[j+a[dp2[i][j] + 1 - 1]],dp2[i][j]+1);
      |                                                   ~~~^~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
In file included from /usr/include/c++/11/string:52,
                 from /usr/include/c++/11/bits/locale_classes.h:40,
                 from /usr/include/c++/11/bits/ios_base.h:41,
                 from /usr/include/c++/11/ios:42,
                 from /usr/include/c++/11/istream:38,
                 from /usr/include/c++/11/sstream:38,
                 from /usr/include/c++/11/complex:45,
                 from /usr/include/c++/11/ccomplex:39,
                 from /usr/include/x86_64-linux-gnu/c++/11/bits/stdc++.h:54,
                 from jelly.cpp:1:
/usr/include/c++/11/bits/stl_algo.h:3467:5: note: candidate: 'template<class _Tp, class _Compare> constexpr _Tp std::max(std::initializer_list<_Tp>, _Compare)'
 3467 |     max(initializer_list<_Tp> __l, _Compare __comp)
      |     ^~~
/usr/include/c++/11/bits/stl_algo.h:3467:5: note:   template argument deduction/substitution failed:
jelly.cpp:89:54: note:   mismatched types 'std::initializer_list<_Tp>' and 'int*'
   89 |                     dp2[j+a[dp2[i][j] + 1 - 1]] = max(dp2[j+a[dp2[i][j] + 1 - 1]],dp2[i][j]+1);
      |                                                   ~~~^~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~