# | Time | Username | Problem | Language | Result | Execution time | Memory |
---|---|---|---|---|---|---|---|
349360 | David_M | 벽 (IOI14_wall) | C++14 | Compilation error | 0 ms | 0 KiB |
This submission is migrated from previous version of oj.uz, which used different machine for grading. This submission may have different result if resubmitted.
include "wall.h"
#include <bits/stdc++.h>
#define pb push_back
using namespace std;
const int INF=1e9+2021;
struct uwu{int type, height, time; uwu (int x, int y, int z){time=z,type=x,height=y;} };
vector<uwu> v[1<<20];
int T[2][1<<22], M[2], K;
void build (int x=1, int l=0, int r=K){
if(l==r){ T[1][x]=(!!l)*INF; return; }
T[1][x]=min(T[1][x<<1], T[1][x<<1|1]);
}
void upd(uwu a, int x=1, int l=0, int r=K){
if(l==r){ T[a.type][x]=a.height; return; }
int mid=l+r>>1;
if(a.time<mid) upd(a, x<<1, l, mid);
else upd(a, x<<1|1, mid+1, r);
T[0][x]=max(T[0][x<<1], T[0][x<<1|1]);
T[1][x]=min(T[1][x<<1], T[1][x<<1|1]);
}
int get(int x=1, int l=0, int r=K){
if(l==r) return (T[0][x]==M[0])?M[1]:M[0];
int m[]={max(M[0], T[0][x<<1|1]), min(M[1], T[1][x<<1|1])}, mid=l+r>>1;
if(m[1]>m[0]){ M[0]=m[0]; M[1]=m[1]; return get(x<<1, l, mid); }
else return get(x<<1|1, mid+1, r);
}
void buildWall(int n, int k, int op[], int left[], int right[],int height[], int finalHeight[]){
build(); K=k;
for(int i=0; i<k; i++){
op[i]--;
v[left[i]].pb({i+1, op[i], height[i]});
v[right[i]+1].pb({i+1, op[i], op[i]==1?0:INF});
}
for (int i=0; i<n; i++){
for (int j=0; j<v[i].size(); j++) upd(v[i][j]);
M[0]=0; M[1]=INF; finalHeight[i]=get();
}
}
Compilation message (stderr)
wall.cpp:1:1: error: 'include' does not name a type 1 | include "wall.h" | ^~~~~~~ In file included from /usr/include/c++/9/cmath:43, from /usr/include/x86_64-linux-gnu/c++/9/bits/stdc++.h:41, from wall.cpp:2: /usr/include/c++/9/ext/type_traits.h:162:35: error: 'bool __gnu_cxx::__is_null_pointer' redeclared as different kind of entity 162 | __is_null_pointer(std::nullptr_t) | ^ /usr/include/c++/9/ext/type_traits.h:157:5: note: previous declaration 'template<class _Type> bool __gnu_cxx::__is_null_pointer(_Type)' 157 | __is_null_pointer(_Type) | ^~~~~~~~~~~~~~~~~ /usr/include/c++/9/ext/type_traits.h:162:26: error: 'nullptr_t' is not a member of 'std' 162 | __is_null_pointer(std::nullptr_t) | ^~~~~~~~~ In file included from /usr/include/c++/9/bits/exception_ptr.h:40, from /usr/include/c++/9/exception:143, from /usr/include/c++/9/ios:39, from /usr/include/c++/9/istream:38, from /usr/include/c++/9/sstream:38, from /usr/include/c++/9/complex:45, from /usr/include/c++/9/ccomplex:39, from /usr/include/x86_64-linux-gnu/c++/9/bits/stdc++.h:54, from wall.cpp:2: /usr/include/c++/9/new:125:50: error: declaration of 'operator new' as non-function 125 | _GLIBCXX_NODISCARD void* operator new(std::size_t) _GLIBCXX_THROW (std::bad_alloc) | ^ /usr/include/c++/9/new:125:44: error: 'size_t' is not a member of 'std'; did you mean 'size_t'? 125 | _GLIBCXX_NODISCARD void* operator new(std::size_t) _GLIBCXX_THROW (std::bad_alloc) | ^~~~~~ In file included from /usr/include/stdlib.h:31, from /usr/include/c++/9/bits/std_abs.h:38, from /usr/include/c++/9/cmath:47, from /usr/include/x86_64-linux-gnu/c++/9/bits/stdc++.h:41, from wall.cpp:2: /usr/lib/gcc/x86_64-linux-gnu/9/include/stddef.h:209:23: note: 'size_t' declared here 209 | typedef __SIZE_TYPE__ size_t; | ^~~~~~ In file included from /usr/include/c++/9/bits/exception_ptr.h:40, from /usr/include/c++/9/exception:143, from /usr/include/c++/9/ios:39, from /usr/include/c++/9/istream:38, from /usr/include/c++/9/sstream:38, from /usr/include/c++/9/complex:45, from /usr/include/c++/9/ccomplex:39, from /usr/include/x86_64-linux-gnu/c++/9/bits/stdc++.h:54, from wall.cpp:2: /usr/include/c++/9/new:126:41: error: attributes after parenthesized initializer ignored [-fpermissive] 126 | __attribute__((__externally_visible__)); | ^ /usr/include/c++/9/new:127:52: error: declaration of 'operator new []' as non-function 127 | _GLIBCXX_NODISCARD void* operator new[](std::size_t) _GLIBCXX_THROW (std::bad_alloc) | ^ /usr/include/c++/9/new:127:46: error: 'size_t' is not a member of 'std'; did you mean 'size_t'? 127 | _GLIBCXX_NODISCARD void* operator new[](std::size_t) _GLIBCXX_THROW (std::bad_alloc) | ^~~~~~ In file included from /usr/include/stdlib.h:31, from /usr/include/c++/9/bits/std_abs.h:38, from /usr/include/c++/9/cmath:47, from /usr/include/x86_64-linux-gnu/c++/9/bits/stdc++.h:41, from wall.cpp:2: /usr/lib/gcc/x86_64-linux-gnu/9/include/stddef.h:209:23: note: 'size_t' declared here 209 | typedef __SIZE_TYPE__ size_t; | ^~~~~~ In file included from /usr/include/c++/9/bits/exception_ptr.h:40, from /usr/include/c++/9/exception:143, from /usr/include/c++/9/ios:39, from /usr/include/c++/9/istream:38, from /usr/include/c++/9/sstream:38, from /usr/include/c++/9/complex:45, from /usr/include/c++/9/ccomplex:39, from /usr/include/x86_64-linux-gnu/c++/9/bits/stdc++.h:54, from wall.cpp:2: /usr/include/c++/9/new:128:41: error: attributes after parenthesized initializer ignored [-fpermissive] 128 | __attribute__((__externally_visible__)); | ^ /usr/include/c++/9/new:134:34: error: 'std::size_t' has not been declared 134 | void operator delete(void*, std::size_t) _GLIBCXX_USE_NOEXCEPT | ^~~~~~ /usr/include/c++/9/new:136:36: error: 'std::size_t' has not been declared 136 | void operator delete[](void*, std::size_t) _GLIBCXX_USE_NOEXCEPT | ^~~~~~ /usr/include/c++/9/new:139:44: error: declaration of 'operator new' as non-function 139 | _GLIBCXX_NODISCARD void* operator new(std::size_t, const std::nothrow_t&) _GLIBCXX_USE_NOEXCEPT | ^~~~~~ /usr/include/c++/9/new:139:44: error: 'size_t' is not a member of 'std'; did you mean 'size_t'? In file included from /usr/include/stdlib.h:31, from /usr/include/c++/9/bits/std_abs.h:38, from /usr/include/c++/9/cmath:47, from /usr/include/x86_64-linux-gnu/c++/9/bits/stdc++.h:41, from wall.cpp:2: /usr/lib/gcc/x86_64-linux-gnu/9/include/stddef.h:209:23: note: 'size_t' declared here 209 | typedef __SIZE_TYPE__ size_t; | ^~~~~~ In file included from /usr/include/c++/9/bits/exception_ptr.h:40, from /usr/include/c++/9/exception:143, from /usr/include/c++/9/ios:39, from /usr/include/c++/9/istream:38, from /usr/include/c++/9/sstream:38, from /usr/include/c++/9/complex:45, from /usr/include/c++/9/ccomplex:39, from /usr/include/x86_64-linux-gnu/c++/9/bits/stdc++.h:54, from wall.cpp:2: /usr/include/c++/9/new:139:52: error: expected primary-expression before 'const' 139 | _GLIBCXX_NODISCARD void* operator new(std::size_t, const std::nothrow_t&) _GLIBCXX_USE_NOEXCEPT | ^~~~~ /usr/include/c++/9/new:141:46: error: declaration of 'operator new []' as non-function 141 | _GLIBCXX_NODISCARD void* operator new[](std::size_t, const std::nothrow_t&) _GLIBCXX_USE_NOEXCEPT | ^~~~~~ /usr/include/c++/9/new:141:46: error: 'size_t' is not a member of 'std'; did you mean 'size_t'? In file included from /usr/include/stdlib.h:31, from /usr/include/c++/9/bits/std_abs.h:38, from /usr/include/c++/9/cmath:47, from /usr/include/x86_64-linux-gnu/c++/9/bits/stdc++.h:41, from wall.cpp:2: /usr/lib/gcc/x86_64-linux-gnu/9/include/stddef.h:209:23: note: 'size_t' declared here 209 | typedef __SIZE_TYPE__ size_t; | ^~~~~~ In file included from /usr/include/c++/9/bits/exception_ptr.h:40, from /usr/include/c++/9/exception:143, from /usr/include/c++/9/ios:39, from /usr/include/c++/9/istream:38, from /usr/include/c++/9/sstream:38, from /usr/include/c++/9/complex:45, from /usr/include/c++/9/ccomplex:39, from /usr/include/x86_64-linux-gnu/c++/9/bits/stdc++.h:54, from wall.cpp:2: /usr/include/c++/9/new:141:54: error: expected primary-expression before 'const' 141 | _GLIBCXX_NODISCARD void* operator new[](std::size_t, const std::nothrow_t&) _GLIBCXX_USE_NOEXCEPT | ^~~~~ /usr/include/c++/9/new:173:51: error: declaration of 'operator new' as non-function 173 | _GLIBCXX_NODISCARD inline void* operator new(std::size_t, void* __p) _GLIBCXX_USE_NOEXCEPT | ^~~~~~ /usr/include/c++/9/new:173:51: error: 'size_t' is not a member of 'std'; did you mean 'size_t'? In file included from /usr/include/stdlib.h:31, from /usr/include/c++/9/bits/std_abs.h:38, from /usr/include/c++/9/cmath:47, from /usr/include/x86_64-linux-gnu/c++/9/bits/stdc++.h:41, from wall.cpp:2: /usr/lib/gcc/x86_64-linux-gnu/9/include/stddef.h:209:23: note: 'size_t' declared here 209 | typedef __SIZE_TYPE__ size_t; | ^~~~~~ In file included from /usr/include/c++/9/bits/exception_ptr.h:40, from /usr/include/c++/9/exception:143, from /usr/include/c++/9/ios:39, from /usr/include/c++/9/istream:38, from /usr/include/c++/9/sstream:38, from /usr/include/c++/9/complex:45, from /usr/include/c++/9/ccomplex:39, from /usr/include/x86_64-linux-gnu/c++/9/bits/stdc++.h:54, from wall.cpp:2: /usr/include/c++/9/new:173:59: error: expected primary-expression before 'void' 173 | _GLIBCXX_NODISCARD inline void* operator new(std::size_t, void* __p) _GLIBCXX_USE_NOEXCEPT | ^~~~ /usr/include/c++/9/new:175:53: error: declaration of 'operator new []' as non-function 175 | _GLIBCXX_NODISCARD inline void* operator new[](std::size_t, void* __p) _GLIBCXX_USE_NOEXCEPT | ^~~~~~ /usr/include/c++/9/new:175:53: error: 'size_t' is not a member of 'std'; did you mean 'size_t'? In file included from /usr/include/stdlib.h:31, from /usr/include/c++/9/bits/std_abs.h:38, from /usr/include/c++/9/cmath:47, from /usr/include/x86_64-linux-gnu/c++/9/bits/stdc++.h:41, from wall.cpp:2: /usr/lib/gcc/x86_64-linux-gnu/9/include/stddef.h:209:23: note: 'size_t' declared here 209 | typedef __SIZE_TYPE__ size_t; | ^~~~~~ In file included from /usr/include/c++/9/bits/exception_ptr.h:40, from /usr/include/c++/9/exception:143, from /usr/include/c++/9/ios:39, from /usr/include/c++/9/istream:38, from /usr/include/c++/9/sstream:38, from /usr/include/c++/9/complex:45, from /usr/include/c++/9/ccomplex:39, from /usr/include/x86_64-linux-gnu/c++/9/bits/stdc++.h:54, from wall.cpp:2: /usr/include/c++/9/new:175:61: error: expected primary-expression before 'void' 175 | _GLIBCXX_NODISCARD inline void* operator new[](std::size_t, void* __p) _GLIBCXX_USE_NOEXCEPT | ^~~~ In file included from /usr/include/c++/9/bits/move.h:55, from /usr/include/c++/9/bits/nested_exception.h:40, from /usr/include/c++/9/exception:144, from /usr/include/c++/9/ios:39, from /usr/include/c++/9/istream:38, from /usr/include/c++/9/sstream:38, from /usr/include/c++/9/complex:45, from /usr/include/c++/9/ccomplex:39, from /usr/include/x86_64-linux-gnu/c++/9/bits/stdc++.h:54, from wall.cpp:2: /usr/include/c++/9/type_traits:361:31: error: 'std::size_t' has not been declared 361 | template<typename _Tp, std::size_t _Size> | ^~~~~~ /usr/include/c++/9/type_traits:362:25: error: '_Size' was not declared in this scope 362 | struct is_array<_Tp[_Size]> | ^~~~~ /usr/include/c++/9/type_traits:362:31: error: template argument 1 is invalid 362 | struct is_array<_Tp[_Size]> | ^ /usr/include/c++/9/type_traits:560:42: error: 'nullptr_t' is not a member of 'std'; did you mean 'nullptr_t'? 560 | struct __is_null_pointer_helper<std::nullptr_t> | ^~~~~~~~~ In file included from /usr/include/c++/9/cstddef:50, from /usr/include/x86_64-linux-gnu/c++/9/bits/stdc++.h:45, from wall.cpp:2: /usr/lib/gcc/x86_64-linux-gnu/9/include/stddef.h:433:29: note: 'nullptr_t' declared here 433 | typedef decltype(nullptr) nullptr_t; | ^~~~~~~~~ In file included from /usr/include/c++/9/bits/move.h:55, from /usr/include/c++/9/bits/nested_exception.h:40, from /usr/include/c++/9/exception:144, from /usr/include/c++/9/ios:39, from /usr/include/c++/9/istream:38, from /usr/include/c++/9/sstream:38, from /usr/include/c++/9/complex:45, from /usr/include/c++/9/ccomplex:39, from /usr/include/x86_64-linux-gnu/c++/9/bits/stdc++.h:54, from wall.cpp:2: /usr/include/c++/9/type_traits:560:42: error: 'nullptr_t' is not a member of 'std'; did you mean 'nullptr_t'? 560 | struct __is_null_pointer_helper<std::nullptr_t> | ^~~~~~~~~ In file included from /usr/include/c++/9/cstddef:50, from /usr/include/x86_64-linux-gnu/c++/9/bits/stdc++.h:45, from wall.cpp:2: /usr/lib/gcc/x86_64-linux-gnu/9/include/stddef.h:433:29: note: 'nullptr_t' declared here 433 | typedef decltype(nullptr) nullptr_t; | ^~~~~~~~~ In file included from /usr/include/c++/9/bits/move.h:55, from /usr/include/c++/9/bits/nested_exception.h:40, from /usr/include/c++/9/exception:144, from /usr/include/c++/9/ios:39, from /usr/include/c++/9/istream:38, from /usr/include/c++/9/sstream:38, from /usr/include/c++/9/complex:45, from /usr/include/c++/9/ccomplex:39, from /usr/include/x86_64-linux-gnu/c++/9/bits/stdc++.h:54, from wall.cpp:2: /usr/include/c++/9/type_traits:560:51: error: template argument 1 is invalid 560 | struct __is_null_pointer_helper<std::nullptr_t> | ^ /usr/include/c++/9/type_traits:1253:37: error: 'size_t' is not a member of 'std'; did you mean 'size_t'? 1253 | : public integral_constant<std::size_t, alignof(_Tp)> { }; | ^~~~~~ In file included from /usr/include/stdlib.h:31, from /usr/include/c++/9/bits/std_abs.h:38, from /usr/include/c++/9/cmath:47, from /usr/include/x86_64-linux-gnu/c++/9/bits/stdc++.h:41, from wall.cpp:2: /usr/lib/gcc/x86_64-linux-gnu/9/include/stddef.h:209:23: note: 'size_t' declared here 209 | typedef __SIZE_TYPE__ size_t; | ^~~~~~ In file included from /usr/include/c++/9/bits/move.h:55, from /usr/include/c++/9/bits/nested_exception.h:40, from /usr/include/c++/9/exception:144, from /usr/include/c++/9/ios:39, from /usr/include/c++/9/istream:38, from /usr/include/c++/9/sstream:38, from /usr/include/c++/9/complex:45, from /usr/include/c++/9/ccomplex:39, from /usr/include/x86_64-linux-gnu/c++/9/bits/stdc++.h:54, from wall.cpp:2: /usr/include/c++/9/type_traits:1253:37: error: 'size_t' is not a member of 'std'; did you mean 'size_t'? 1253 | : public integral_constant<std::size_t, alignof(_Tp)> { }; | ^~~~~~ In file included from /usr/include/stdlib.h:31, from /usr/include/c++/9/bits/std_abs.h:38, from /usr/include/c++/9/cmath:47, from /usr/include/x86_64-linux-gnu/c++/9/bits/stdc++.h:41, from wall.cpp:2: /usr/lib/gcc/x86_64-linux-gnu/9/include/stddef.h:209:23: note: 'size_t' declared here 209 | typedef __SIZE_TYPE__ size_t; | ^~~~~~ In file included from /usr/include/c++/9/bits/move.h:55, from /usr/include/c++/9/bits/nested_exception.h:40, from /usr/include/c++/9/exception:144, from /usr/include/c++/9/ios:39, from /usr/include/c++/9/istream:38, from /usr/include/c++/9/sstream:38, from /usr/include/c++/9/complex:45, from /usr/include/c++/9/ccomplex:39, from /usr/include/x86_64-linux-gnu/c++/9/bits/stdc++.h:54, from wall.cpp:2: /usr/include/c++/9/type_traits:1253:57: error: template argument 1 is invalid 1253 | : public integral_constant<std::size_t, alignof(_Tp)> { }; | ^ /usr/include/c++/9/type_traits:1253:57: note: invalid template non-type parameter /usr/include/c++/9/type_traits:1258:37: error: 'size_t' is not a member of 'std'; did you mean 'size_t'? 1258 | : public integral_constant<std::size_t, 0> { }; | ^~~~~~ In file included from /usr/include/stdlib.h:31, from /usr/include/c++/9/bits/std_abs.h:38, from /usr/include/c++/9/cmath:47, from /usr/include/x86_64-linux-gnu/c++/9/bits/stdc++.h:41, from wall.cpp:2: /usr/lib/gcc/x86_64-linux-gnu/9/include/stddef.h:209:23: note: 'size_t' declared here 209 | typedef __SIZE_TYPE__ size_t; | ^~~~~~ In file included from /usr/include/c++/9/bits/move.h:55, from /usr/include/c++/9/bits/nested_exception.h:40, from /usr/include/c++/9/exception:144, from /usr/include/c++/9/ios:39, from /usr/include/c++/9/istream:38, from /usr/include/c++/9/sstream:38, from /usr/include/c++/9/complex:45, from /usr/include/c++/9/ccomplex:39, from /usr/include/x86_64-linux-gnu/c++/9/bits/stdc++.h:54, from wall.cpp:2: /usr/include/c++/9/type_traits:1258:37: error: 'size_t' is not a member of 'std'; did you mean 'size_t'? 1258 | : public integral_constant<std::size_t, 0> { }; | ^~~~~~ In file included from /usr/include/stdlib.h:31, from /usr/include/c++/9/bits/std_abs.h:38, from /usr/include/c++/9/cmath:47, from /usr/include/x86_64-linux-gnu/c++/9/bits/stdc++.h:41, from wall.cpp:2: /usr/lib/gcc/x86_64-linux-gnu/9/include/stddef.h:209:23: note: 'size_t' declared here 209 | typedef __SIZE_TYPE__ size_t; | ^~~~~~ In file included