제출 #1169045

#제출 시각아이디문제언어결과실행 시간메모리
1169045bbartekJelly Flavours (IOI20_jelly)C++20
컴파일 에러
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(dp[i][j] == 0){ dp[i][j] = start; } if(i + a[dp[i][j] + 1 - 1] <= x){ dp[i+a[dp[i][j] + 1 - 1]] = max(dp[i+a[dp[i][j] + 1 - 1]],dp[i][j]+1); } if(j + a[dp[i][j] + 1 - 1] <= y){ dp[j+a[dp[i][j] + 1 - 1]] = max(dp[j+a[dp[i][j] + 1 - 1]],dp[i][j]+1); } } } return dp[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]; }

컴파일 시 표준 에러 (stderr) 메시지

jelly.cpp: In function 'int find_maximum_unique(int, int, std::vector<int>, std::vector<int>)':
jelly.cpp:83:30: error: incompatible types in assignment of 'int' to 'int [503]'
   83 |                     dp[i][j] = start;
      |                     ~~~~~~~~~^~~~~~~
jelly.cpp:85:39: error: invalid conversion from 'int*' to 'std::vector<int>::size_type' {aka 'long unsigned int'} [-fpermissive]
   85 |                 if(i + a[dp[i][j] + 1 - 1] <= x){
      |                          ~~~~~~~~~~~~~^~~
      |                                       |
      |                                       int*
In file included from /usr/include/c++/11/vector:67,
                 from /usr/include/c++/11/functional:62,
                 from /usr/include/c++/11/pstl/glue_algorithm_defs.h:13,
                 from /usr/include/c++/11/algorithm:74,
                 from /usr/include/x86_64-linux-gnu/c++/11/bits/stdc++.h:65,
                 from jelly.cpp:1:
/usr/include/c++/11/bits/stl_vector.h:1043:28: note:   initializing argument 1 of 'std::vector<_Tp, _Alloc>::reference std::vector<_Tp, _Alloc>::operator[](std::vector<_Tp, _Alloc>::size_type) [with _Tp = int; _Alloc = std::allocator<int>; std::vector<_Tp, _Alloc>::reference = int&; std::vector<_Tp, _Alloc>::size_type = long unsigned int]'
 1043 |       operator[](size_type __n) _GLIBCXX_NOEXCEPT
      |                  ~~~~~~~~~~^~~
jelly.cpp:86:41: error: invalid conversion from 'int*' to 'std::vector<int>::size_type' {aka 'long unsigned int'} [-fpermissive]
   86 |                     dp[i+a[dp[i][j] + 1 - 1]] = max(dp[i+a[dp[i][j] + 1 - 1]],dp[i][j]+1);
      |                            ~~~~~~~~~~~~~^~~
      |                                         |
      |                                         int*
In file included from /usr/include/c++/11/vector:67,
                 from /usr/include/c++/11/functional:62,
                 from /usr/include/c++/11/pstl/glue_algorithm_defs.h:13,
                 from /usr/include/c++/11/algorithm:74,
                 from /usr/include/x86_64-linux-gnu/c++/11/bits/stdc++.h:65,
                 from jelly.cpp:1:
/usr/include/c++/11/bits/stl_vector.h:1043:28: note:   initializing argument 1 of 'std::vector<_Tp, _Alloc>::reference std::vector<_Tp, _Alloc>::operator[](std::vector<_Tp, _Alloc>::size_type) [with _Tp = int; _Alloc = std::allocator<int>; std::vector<_Tp, _Alloc>::reference = int&; std::vector<_Tp, _Alloc>::size_type = long unsigned int]'
 1043 |       operator[](size_type __n) _GLIBCXX_NOEXCEPT
      |                  ~~~~~~~~~~^~~
jelly.cpp:86:73: error: invalid conversion from 'int*' to 'std::vector<int>::size_type' {aka 'long unsigned int'} [-fpermissive]
   86 |                     dp[i+a[dp[i][j] + 1 - 1]] = max(dp[i+a[dp[i][j] + 1 - 1]],dp[i][j]+1);
      |                                                            ~~~~~~~~~~~~~^~~
      |                                                                         |
      |                                                                         int*
In file included from /usr/include/c++/11/vector:67,
                 from /usr/include/c++/11/functional:62,
                 from /usr/include/c++/11/pstl/glue_algorithm_defs.h:13,
                 from /usr/include/c++/11/algorithm:74,
                 from /usr/include/x86_64-linux-gnu/c++/11/bits/stdc++.h:65,
                 from jelly.cpp:1:
/usr/include/c++/11/bits/stl_vector.h:1043:28: note:   initializing argument 1 of 'std::vector<_Tp, _Alloc>::reference std::vector<_Tp, _Alloc>::operator[](std::vector<_Tp, _Alloc>::size_type) [with _Tp = int; _Alloc = std::allocator<int>; std::vector<_Tp, _Alloc>::reference = int&; std::vector<_Tp, _Alloc>::size_type = long unsigned int]'
 1043 |       operator[](size_type __n) _GLIBCXX_NOEXCEPT
      |                  ~~~~~~~~~~^~~
jelly.cpp:86:52: error: no matching function for call to 'max(int [503][503], int*)'
   86 |                     dp[i+a[dp[i][j] + 1 - 1]] = max(dp[i+a[dp[i][j] + 1 - 1]],dp[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:52: note:   deduced conflicting types for parameter 'const _Tp' ('int [503][503]' and 'int*')
   86 |                     dp[i+a[dp[i][j] + 1 - 1]] = max(dp[i+a[dp[i][j] + 1 - 1]],dp[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:52: note:   deduced conflicting types for parameter 'const _Tp' ('int [503][503]' and 'int*')
   86 |                     dp[i+a[dp[i][j] + 1 - 1]] = max(dp[i+a[dp[i][j] + 1 - 1]],dp[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:52: note:   mismatched types 'std::initializer_list<_Tp>' and 'int (*)[503]'
   86 |                     dp[i+a[dp[i][j] + 1 - 1]] = max(dp[i+a[dp[i][j] + 1 - 1]],dp[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:52: note:   mismatched types 'std::initializer_list<_Tp>' and 'int (*)[503]'
   86 |                     dp[i+a[dp[i][j] + 1 - 1]] = max(dp[i+a[dp[i][j] + 1 - 1]],dp[i][j]+1);
      |                                                 ~~~^~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
jelly.cpp:88:39: error: invalid conversion from 'int*' to 'std::vector<int>::size_type' {aka 'long unsigned int'} [-fpermissive]
   88 |                 if(j + a[dp[i][j] + 1 - 1] <= y){
      |                          ~~~~~~~~~~~~~^~~
      |                                       |
      |                                       int*
In file included from /usr/include/c++/11/vector:67,
                 from /usr/include/c++/11/functional:62,
                 from /usr/include/c++/11/pstl/glue_algorithm_defs.h:13,
                 from /usr/include/c++/11/algorithm:74,
                 from /usr/include/x86_64-linux-gnu/c++/11/bits/stdc++.h:65,
                 from jelly.cpp:1:
/usr/include/c++/11/bits/stl_vector.h:1043:28: note:   initializing argument 1 of 'std::vector<_Tp, _Alloc>::reference std::vector<_Tp, _Alloc>::operator[](std::vector<_Tp, _Alloc>::size_type) [with _Tp = int; _Alloc = std::allocator<int>; std::vector<_Tp, _Alloc>::reference = int&; std::vector<_Tp, _Alloc>::size_type = long unsigned int]'
 1043 |       operator[](size_type __n) _GLIBCXX_NOEXCEPT
      |                  ~~~~~~~~~~^~~
jelly.cpp:89:41: error: invalid conversion from 'int*' to 'std::vector<int>::size_type' {aka 'long unsigned int'} [-fpermissive]
   89 |                     dp[j+a[dp[i][j] + 1 - 1]] = max(dp[j+a[dp[i][j] + 1 - 1]],dp[i][j]+1);
      |                            ~~~~~~~~~~~~~^~~
      |                                         |
      |                                         int*
In file included from /usr/include/c++/11/vector:67,
                 from /usr/include/c++/11/functional:62,
                 from /usr/include/c++/11/pstl/glue_algorithm_defs.h:13,
                 from /usr/include/c++/11/algorithm:74,
                 from /usr/include/x86_64-linux-gnu/c++/11/bits/stdc++.h:65,
                 from jelly.cpp:1:
/usr/include/c++/11/bits/stl_vector.h:1043:28: note:   initializing argument 1 of 'std::vector<_Tp, _Alloc>::reference std::vector<_Tp, _Alloc>::operator[](std::vector<_Tp, _Alloc>::size_type) [with _Tp = int; _Alloc = std::allocator<int>; std::vector<_Tp, _Alloc>::reference = int&; std::vector<_Tp, _Alloc>::size_type = long unsigned int]'
 1043 |       operator[](size_type __n) _GLIBCXX_NOEXCEPT
      |                  ~~~~~~~~~~^~~
jelly.cpp:89:73: error: invalid conversion from 'int*' to 'std::vector<int>::size_type' {aka 'long unsigned int'} [-fpermissive]
   89 |                     dp[j+a[dp[i][j] + 1 - 1]] = max(dp[j+a[dp[i][j] + 1 - 1]],dp[i][j]+1);
      |                                                            ~~~~~~~~~~~~~^~~
      |                                                                         |
      |                                                                         int*
In file included from /usr/include/c++/11/vector:67,
                 from /usr/include/c++/11/functional:62,
                 from /usr/include/c++/11/pstl/glue_algorithm_defs.h:13,
                 from /usr/include/c++/11/algorithm:74,
                 from /usr/include/x86_64-linux-gnu/c++/11/bits/stdc++.h:65,
                 from jelly.cpp:1:
/usr/include/c++/11/bits/stl_vector.h:1043:28: note:   initializing argument 1 of 'std::vector<_Tp, _Alloc>::reference std::vector<_Tp, _Alloc>::operator[](std::vector<_Tp, _Alloc>::size_type) [with _Tp = int; _Alloc = std::allocator<int>; std::vector<_Tp, _Alloc>::reference = int&; std::vector<_Tp, _Alloc>::size_type = long unsigned int]'
 1043 |       operator[](size_type __n) _GLIBCXX_NOEXCEPT
      |                  ~~~~~~~~~~^~~
jelly.cpp:89:52: error: no matching function for call to 'max(int [503][503], int*)'
   89 |                     dp[j+a[dp[i][j] + 1 - 1]] = max(dp[j+a[dp[i][j] + 1 - 1]],dp[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:52: note:   deduced conflicting types for parameter 'const _Tp' ('int [503][503]' and 'int*')
   89 |                     dp[j+a[dp[i][j] + 1 - 1]] = max(dp[j+a[dp[i][j] + 1 - 1]],dp[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:52: note:   deduced conflicting types for parameter 'const _Tp' ('int [503][503]' and 'int*')
   89 |                     dp[j+a[dp[i][j] + 1 - 1]] = max(dp[j+a[dp[i][j] + 1 - 1]],dp[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:52: note:   mismatched types 'std::initializer_list<_Tp>' and 'int (*)[503]'
   89 |                     dp[j+a[dp[i][j] + 1 - 1]] = max(dp[j+a[dp[i][j] + 1 - 1]],dp[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:52: note:   mismatched types 'std::initializer_list<_Tp>' and 'int (*)[503]'
   89 |                     dp[j+a[dp[i][j] + 1 - 1]] = max(dp[j+a[dp[i][j] + 1 - 1]],dp[i][j]+1);
      |                                                 ~~~^~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
jelly.cpp:93:23: error: invalid conversion from 'int*' to 'int' [-fpermissive]
   93 |         return dp[x][y];
      |                ~~~~~~~^
      |                       |
      |                       int*