제출 #1159268

#제출 시각아이디문제언어결과실행 시간메모리
1159268Gr1sen늑대인간 (IOI18_werewolf)C++17
컴파일 에러
0 ms0 KiB
#include "werewolf.h" #include<iostream> #include<queue> using namespace std; #define vi vector<int> #define vvi vector<vi> #define qq queue<tuple<int, int>> #define ti tuple<int, int> #define G(a, b) get<a>(b) vvi Adj; bool oink(int a, int b, int l, int r) { vi M(Adj.size(), 0); if (a == b) return 1; qq Q; Q.push(ti({a, 1})); Q.push(ti({b, 2})); while (!Q.empty()) { int c = G(0, Q.front()), d = G(1, Q.front()); Q.pop(); if (d == 1 && c < l) continue; if (d == 2 && c > r) continue; if (M[c] != 0) { if (M[c] == d) continue; return 1; } M[c] = d; for (auto i : Adj[c]) { Q.push(ti({i, d})); } } return 0; } vector<int> check_validity(int N, vector<int> X, vector<int> Y,vector<int> S, vector<int> E, vector<int> L, vector<int> R) { int Q = S.size(); Adj = vvi(N); //cerr << "Adj start" << endl; for (int i = 0; i < X.size(); i++) { Adj[X[i]].push_back(Y[i]); Adj[Y[i]].push_back(X[i]); } //cerr << "Adj end" << endl; vector<int> A(Q); for (int i = 0; i < Q; ++i) { A[i] = oink(S[i], E[i], L[i], R[i]); } return A; } /* 6 6 3 5 1 1 2 1 3 3 4 3 0 5 2 4 2 1 2 4 2 2 2 5 4 3 4 */

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

werewolf.cpp: In function 'bool oink(int, int, int, int)':
werewolf.cpp:19:25: error: invalid use of incomplete type 'class std::tuple<int, int>'
   19 |         Q.push(ti({a, 1}));
      |                         ^
In file included from /usr/include/c++/11/bits/move.h:57,
                 from /usr/include/c++/11/bits/stl_pair.h:59,
                 from /usr/include/c++/11/bits/stl_algobase.h:64,
                 from /usr/include/c++/11/vector:60,
                 from werewolf.h:3,
                 from werewolf.cpp:1:
/usr/include/c++/11/type_traits:45:11: note: declaration of 'class std::tuple<int, int>'
   45 |     class tuple;
      |           ^~~~~
werewolf.cpp:20:25: error: invalid use of incomplete type 'class std::tuple<int, int>'
   20 |         Q.push(ti({b, 2}));
      |                         ^
In file included from /usr/include/c++/11/bits/move.h:57,
                 from /usr/include/c++/11/bits/stl_pair.h:59,
                 from /usr/include/c++/11/bits/stl_algobase.h:64,
                 from /usr/include/c++/11/vector:60,
                 from werewolf.h:3,
                 from werewolf.cpp:1:
/usr/include/c++/11/type_traits:45:11: note: declaration of 'class std::tuple<int, int>'
   45 |     class tuple;
      |           ^~~~~
werewolf.cpp:11:17: error: 'get' was not declared in this scope; did you mean 'getw'?
   11 | #define G(a, b) get<a>(b)
      |                 ^~~
werewolf.cpp:22:25: note: in expansion of macro 'G'
   22 |                 int c = G(0, Q.front()), d = G(1, Q.front());
      |                         ^
werewolf.cpp:24:21: error: 'd' was not declared in this scope
   24 |                 if (d == 1 && c < l) continue;
      |                     ^
werewolf.cpp:25:21: error: 'd' was not declared in this scope
   25 |                 if (d == 2 && c > r) continue;
      |                     ^
werewolf.cpp:27:37: error: 'd' was not declared in this scope
   27 |                         if (M[c] == d) continue;
      |                                     ^
werewolf.cpp:30:24: error: 'd' was not declared in this scope
   30 |                 M[c] = d;
      |                        ^
werewolf.cpp:32:41: error: invalid use of incomplete type 'class std::tuple<int, int>'
   32 |                         Q.push(ti({i, d}));
      |                                         ^
In file included from /usr/include/c++/11/bits/move.h:57,
                 from /usr/include/c++/11/bits/stl_pair.h:59,
                 from /usr/include/c++/11/bits/stl_algobase.h:64,
                 from /usr/include/c++/11/vector:60,
                 from werewolf.h:3,
                 from werewolf.cpp:1:
/usr/include/c++/11/type_traits:45:11: note: declaration of 'class std::tuple<int, int>'
   45 |     class tuple;
      |           ^~~~~
In file included from /usr/include/c++/11/deque:67,
                 from /usr/include/c++/11/queue:60,
                 from werewolf.cpp:3:
/usr/include/c++/11/bits/stl_deque.h: In instantiation of 'void std::deque<_Tp, _Alloc>::_M_destroy_data(std::deque<_Tp, _Alloc>::iterator, std::deque<_Tp, _Alloc>::iterator, const std::allocator<_Tp1>&) [with _Tp = std::tuple<int, int>; _Alloc = std::allocator<std::tuple<int, int> >; std::deque<_Tp, _Alloc>::iterator = std::_Deque_base<std::tuple<int, int>, std::allocator<std::tuple<int, int> > >::iterator]':
/usr/include/c++/11/bits/stl_deque.h:1007:24:   required from 'std::deque<_Tp, _Alloc>::~deque() [with _Tp = std::tuple<int, int>; _Alloc = std::allocator<std::tuple<int, int> >]'
/usr/include/c++/11/bits/stl_queue.h:96:11:   required from here
/usr/include/c++/11/bits/stl_deque.h:2048:14: error: invalid use of incomplete type 'std::deque<std::tuple<int, int>, std::allocator<std::tuple<int, int> > >::value_type' {aka 'class std::tuple<int, int>'}
 2048 |         if (!__has_trivial_destructor(value_type))
      |              ^~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
In file included from /usr/include/c++/11/bits/move.h:57,
                 from /usr/include/c++/11/bits/stl_pair.h:59,
                 from /usr/include/c++/11/bits/stl_algobase.h:64,
                 from /usr/include/c++/11/vector:60,
                 from werewolf.h:3,
                 from werewolf.cpp:1:
/usr/include/c++/11/type_traits:45:11: note: declaration of 'std::deque<std::tuple<int, int>, std::allocator<std::tuple<int, int> > >::value_type' {aka 'class std::tuple<int, int>'}
   45 |     class tuple;
      |           ^~~~~
In file included from /usr/include/c++/11/deque:67,
                 from /usr/include/c++/11/queue:60,
                 from werewolf.cpp:3:
/usr/include/c++/11/bits/stl_deque.h: In instantiation of 'void std::deque<_Tp, _Alloc>::pop_front() [with _Tp = std::tuple<int, int>; _Alloc = std::allocator<std::tuple<int, int> >]':
/usr/include/c++/11/bits/stl_queue.h:301:13:   required from 'void std::queue<_Tp, _Sequence>::pop() [with _Tp = std::tuple<int, int>; _Sequence = std::deque<std::tuple<int, int>, std::allocator<std::tuple<int, int> > >]'
werewolf.cpp:23:8:   required from here
/usr/include/c++/11/bits/stl_deque.h:1536:47: error: invalid use of incomplete type 'class std::tuple<int, int>'
 1536 |             != this->_M_impl._M_start._M_last - 1)
      |                ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~^~~
In file included from /usr/include/c++/11/bits/move.h:57,
                 from /usr/include/c++/11/bits/stl_pair.h:59,
                 from /usr/include/c++/11/bits/stl_algobase.h:64,
                 from /usr/include/c++/11/vector:60,
                 from werewolf.h:3,
                 from werewolf.cpp:1:
/usr/include/c++/11/type_traits:45:11: note: declaration of 'class std::tuple<int, int>'
   45 |     class tuple;
      |           ^~~~~
In file included from /usr/include/c++/11/deque:67,
                 from /usr/include/c++/11/queue:60,
                 from werewolf.cpp:3:
/usr/include/c++/11/bits/stl_deque.h:1540:38: error: cannot increment a pointer to incomplete type 'std::tuple<int, int>'
 1540 |             ++this->_M_impl._M_start._M_cur;
      |               ~~~~~~~~~~~~~~~~~~~~~~~^~~~~~
/usr/include/c++/11/bits/stl_deque.h: In instantiation of 'void std::_Deque_base<_Tp, _Alloc>::_M_initialize_map(std::size_t) [with _Tp = std::tuple<int, int>; _Alloc = std::allocator<std::tuple<int, int> >; std::size_t = long unsigned int]':
/usr/include/c++/11/bits/stl_deque.h:439:9:   required from 'std::_Deque_base<_Tp, _Alloc>::_Deque_base() [with _Tp = std::tuple<int, int>; _Alloc = std::allocator<std::tuple<int, int> >]'
/usr/include/c++/11/bits/stl_deque.h:834:7:   required from 'std::queue<_Tp, _Sequence>::queue() [with _Seq = std::deque<std::tuple<int, int>, std::allocator<std::tuple<int, int> > >; _Requires = void; _Tp = std::tuple<int, int>; _Sequence = std::deque<std::tuple<int, int>, std::allocator<std::tuple<int, int> > >]'
werewolf.cpp:18:5:   required from here
/usr/include/c++/11/bits/stl_deque.h:620:69: error: invalid application of 'sizeof' to incomplete type 'std::tuple<int, int>'
  620 |       const size_t __num_nodes = (__num_elements / __deque_buf_size(sizeof(_Tp))
      |                                                                     ^~~~~~~~~~~
/usr/include/c++/11/bits/stl_deque.h:651:60: error: invalid application of 'sizeof' to incomplete type 'std::tuple<int, int>'
  651 |                                         % __deque_buf_size(sizeof(_Tp)));
      |                                                            ^~~~~~~~~~~
/usr/include/c++/11/bits/stl_deque.h: In instantiation of 'void std::_Deque_base<_Tp, _Alloc>::_M_deallocate_node(std::_Deque_base<_Tp, _Alloc>::_Ptr) [with _Tp = std::tuple<int, int>; _Alloc = std::allocator<std::tuple<int, int> >; std::_Deque_base<_Tp, _Alloc>::_Ptr = std::tuple<int, int>*]':
/usr/include/c++/11/bits/stl_deque.h:679:2:   required from 'void std::_Deque_base<_Tp, _Alloc>::_M_destroy_nodes(std::_Deque_base<_Tp, _Alloc>::_Map_pointer, std::_Deque_base<_Tp, _Alloc>::_Map_pointer) [with _Tp = std::tuple<int, int>; _Alloc = std::allocator<std::tuple<int, int> >; std::_Deque_base<_Tp, _Alloc>::_Map_pointer = std::tuple<int, int>**]'
/usr/include/c++/11/bits/stl_deque.h:601:4:   required from 'std::_Deque_base<_Tp, _Alloc>::~_Deque_base() [with _Tp = std::tuple<int, int>; _Alloc = std::allocator<std::tuple<int, int> >]'
/usr/include/c++/11/bits/stl_deque.h:834:7:   required from 'std::queue<_Tp, _Sequence>::queue() [with _Seq = std::deque<std::tuple<int, int>, std::allocator<std::tuple<int, int> > >; _Requires = void; _Tp = std::tuple<int, int>; _Sequence = std::deque<std::tuple<int, int>, std::allocator<std::tuple<int, int> > >]'
werewolf.cpp:18:5:   required from here
/usr/include/c++/11/bits/stl_deque.h:569:60: error: invalid application of 'sizeof' to incomplete type 'std::tuple<int, int>'
  569 |         _Traits::deallocate(_M_impl, __p, __deque_buf_size(sizeof(_Tp)));
      |                                                            ^~~~~~~~~~~
In file included from /usr/include/x86_64-linux-gnu/c++/11/bits/c++allocator.h:33,
                 from /usr/include/c++/11/bits/allocator.h:46,
                 from /usr/include/c++/11/vector:64,
                 from werewolf.h:3,
                 from werewolf.cpp:1:
/usr/include/c++/11/ext/new_allocator.h: In instantiation of 'void __gnu_cxx::new_allocator<_Tp>::deallocate(_Tp*, __gnu_cxx::new_allocator<_Tp>::size_type) [with _Tp = std::tuple<int, int>; __gnu_cxx::new_allocator<_Tp>::size_type = long unsigned int]':
/usr/include/c++/11/bits/alloc_traits.h:496:23:   required from 'static void std::allocator_traits<std::allocator<_Tp1> >::deallocate(std::allocator_traits<std::allocator<_Tp1> >::allocator_type&, std::allocator_traits<std::allocator<_Tp1> >::pointer, std::allocator_traits<std::allocator<_Tp1> >::size_type) [with _Tp = std::tuple<int, int>; std::allocator_traits<std::allocator<_Tp1> >::allocator_type = std::allocator<std::tuple<int, int> >; std::allocator_traits<std::allocator<_Tp1> >::pointer = std::tuple<int, int>*; std::allocator_traits<std::allocator<_Tp1> >::size_type = long unsigned int]'
/usr/include/c++/11/bits/stl_deque.h:569:21:   required from 'void std::_Deque_base<_Tp, _Alloc>::_M_deallocate_node(std::_Deque_base<_Tp, _Alloc>::_Ptr) [with _Tp = std::tuple<int, int>; _Alloc = std::allocator<std::tuple<int, int> >; std::_Deque_base<_Tp, _Alloc>::_Ptr = std::tuple<int, int>*]'
/usr/include/c++/11/bits/stl_deque.h:679:2:   required from 'void std::_Deque_base<_Tp, _Alloc>::_M_destroy_nodes(std::_Deque_base<_Tp, _Alloc>::_Map_pointer, std::_Deque_base<_Tp, _Alloc>::_Map_pointer) [with _Tp = std::tuple<int, int>; _Alloc = std::allocator<std::tuple<int, int> >; std::_Deque_base<_Tp, _Alloc>::_Map_pointer = std::tuple<int, int>**]'
/usr/include/c++/11/bits/stl_deque.h:601:4:   required from 'std::_Deque_base<_Tp, _Alloc>::~_Deque_base() [with _Tp = std::tuple<int, int>; _Alloc = std::allocator<std::tuple<int, int> >]'
/usr/include/c++/11/bits/stl_deque.h:834:7:   required from 'std::queue<_Tp, _Sequence>::queue() [with _Seq = std::deque<std::tuple<int, int>, std::allocator<std::tuple<int, int> > >; _Requires = void; _Tp = std::tuple<int, int>; _Sequence = std::deque<std::tuple<int, int>, std::allocator<std::tuple<int, int> > >]'
werewolf.cpp:18:5:   required from here
/usr/include/c++/11/ext/new_allocator.h:135:13: error: invalid application of '__alignof__' to incomplete type 'std::tuple<int, int>'
  135 |         if (alignof(_Tp) > __STDCPP_DEFAULT_NEW_ALIGNMENT__)
      |             ^~~~~~~~~~~~
/usr/include/c++/11/ext/new_allocator.h:139:37: error: invalid application of 'sizeof' to incomplete type 'std::tuple<int, int>'
  139 |                               __t * sizeof(_Tp),
      |                                     ^~~~~~~~~~~
/usr/include/c++/11/ext/new_allocator.h:141:48: error: invalid application of '__alignof__' to incomplete type 'std::tuple<int, int>'
  141 |                               std::align_val_t(alignof(_Tp)));
      |                                                ^~~~~~~~~~~~
/usr/include/c++/11/ext/new_allocator.h:147:35: error: invalid application of 'sizeof' to incomplete type 'std::tuple<int, int>'
  147 |                           , __t * sizeof(_Tp)
      |                                   ^~~~~~~~~~~