제출 #1275946

#제출 시각아이디문제언어결과실행 시간메모리
1275946domiElection (BOI18_election)C++20
컴파일 에러
0 ms0 KiB
#include <bits/stdc++.h>

#define int long long
#define fi first
#define se second

#define sz(a) (int)((a).size())
#define all(a) (a).begin(), (a).end()

#define lsb(x) (x & (-x))
#define vi vector<int>
#define YES { cout << "YES" << endl; return; }
#define NO { cout << "NO" << endl; return; }

//using ll = long long;
using pii = std::pair<int, int>;

const int NMAX = 5e5;

using namespace std;

vector<pii>qu[NMAX + 5];
vector<int>stk;
char ch;
int a[NMAX + 5], ans[NMAX + 5], n, q;

///cate numere din stk sunt <= r
inline int cate(int r){
    if (stk.empty()) return 0;
    return upper_bound(stk.rbegin(), stk.rend(), r) - stk.begin();
}

struct Node{
    int sum;
    int min_suf;

    Node () : sum(0), min_suf(0) {}

    Node (int x) : sum(x), min_suf(min(0LL, x)) {}

    static Node merge(const Node& left, const Node& right){
        Node aux;
        aux.sum = left.sum + right.sum;
        aux.min_suf = min(right.min_suf, right.sum + left.min_suf);
        return aux;
    }

};

struct ST{

    Node aint[4 * NMAX + 5];

    void build(int nod = 1, int st = 1, int dr = n){
        if (st == dr){
            aint[nod] = Node(a[st]);
            return;
        }

        int m = (st + dr) >> 1;
        build(2 * nod, st, m);
        build(2 * nod + 1, m + 1, dr);
        aint[nod] = Node::merge(aint[2 * nod], aint[2 * nod + 1]);
    }

    void update(int pos, int val, int nod = 1, int st = 1, int dr = n){
        if (st == dr){
            aint[nod] = Node(val);
            return;
        }

        int m = (st + dr) >> 1;
        if (pos <= m)
            update(pos, val, 2 * nod, st, m);
        else
            update(pos, val, 2 * nod + 1, m + 1, dr);
        aint[nod] = Node::merge(aint[2 * nod], aint[2 * nod + 1]);
    }

    Node query(int l, int r, int nod = 1, int st = 1, int dr = n){
        if (st > r || dr < l) return Node();
        if (l <= st && dr <= r) return aint[nod];

        int m = (st + dr) >> 1;
        return Node::merge(query(l, r, 2 * nod, st, m), query(l, r, 2 * nod + 1, m + 1, dr));
     }


}aint;

signed main() {
    cin.tie(nullptr)->sync_with_stdio(false);
    cin >> n;

    for (int i = 1; i <= n; ++i){
        cin >> ch;
        a[i] = (ch == 'C' ? 1 : -1);
    }

    cin >> q;
    for (int i = 1, l, r; i <= q; ++i){
        cin >> l >> r;
        qu[l].push_back({r, i});
    }

    aint.build();
    for (int i = n; i >= 1; ++i){

        if (a[i] == 1){
            if (!st.empty()){
                aint.update(st.back(), -1);
                st.pop_back();
            }
        }

        if (a[i] == -1){
            aint.update(i, 0);
            stk.push_back(i);
        }

        for (auto &[r, idx] : qu[i])
            ans[idx] = cate(r) - aint.query(i, r).min_suf;
    }

    for (int i = 1; i <= q; ++i)
        cout << ans[i] << '\n';
    return 0;
}

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

election.cpp: In function 'long long int cate(long long int)':
election.cpp:30:53: error: no match for 'operator-' (operand types are 'std::reverse_iterator<__gnu_cxx::__normal_iterator<long long int*, std::vector<long long int> > >' and 'std::vector<long long int>::iterator')
   30 |     return upper_bound(stk.rbegin(), stk.rend(), r) - stk.begin();
      |            ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ ^ ~~~~~~~~~~~
      |                       |                                        |
      |                       |                                        std::vector<long long int>::iterator
      |                       std::reverse_iterator<__gnu_cxx::__normal_iterator<long long int*, std::vector<long long int> > >
In file included from /usr/include/c++/13/bits/stl_algobase.h:67,
                 from /usr/include/c++/13/algorithm:60,
                 from /usr/include/x86_64-linux-gnu/c++/13/bits/stdc++.h:51,
                 from election.cpp:1:
/usr/include/c++/13/bits/stl_iterator.h:370:7: note: candidate: 'constexpr std::reverse_iterator<_Iterator> std::reverse_iterator<_Iterator>::operator-(difference_type) const [with _Iterator = __gnu_cxx::__normal_iterator<long long int*, std::vector<long long int> >; difference_type = long int]'
  370 |       operator-(difference_type __n) const
      |       ^~~~~~~~
/usr/include/c++/13/bits/stl_iterator.h:370:33: note:   no known conversion for argument 1 from 'std::vector<long long int>::iterator' to 'std::reverse_iterator<__gnu_cxx::__normal_iterator<long long int*, std::vector<long long int> > >::difference_type' {aka 'long int'}
  370 |       operator-(difference_type __n) const
      |                 ~~~~~~~~~~~~~~~~^~~
/usr/include/c++/13/bits/stl_iterator.h:625:5: note: candidate: 'template<class _IteratorL, class _IteratorR> constexpr decltype ((__y.base() - __x.base())) std::operator-(const reverse_iterator<_IteratorL>&, const reverse_iterator<_IteratorR>&)'
  625 |     operator-(const reverse_iterator<_IteratorL>& __x,
      |     ^~~~~~~~
/usr/include/c++/13/bits/stl_iterator.h:625:5: note:   template argument deduction/substitution failed:
election.cpp:30:65: note:   'std::vector<long long int>::iterator' is not derived from 'const std::reverse_iterator<_IteratorR>'
   30 |     return upper_bound(stk.rbegin(), stk.rend(), r) - stk.begin();
      |                                                                 ^
/usr/include/c++/13/bits/stl_iterator.h:1800:5: note: candidate: 'template<class _IteratorL, class _IteratorR> constexpr decltype ((__x.base() - __y.base())) std::operator-(const move_iterator<_IteratorL>&, const move_iterator<_IteratorR>&)'
 1800 |     operator-(const move_iterator<_IteratorL>& __x,
      |     ^~~~~~~~
/usr/include/c++/13/bits/stl_iterator.h:1800:5: note:   template argument deduction/substitution failed:
election.cpp:30:65: note:   'std::reverse_iterator<__gnu_cxx::__normal_iterator<long long int*, std::vector<long long int> > >' is not derived from 'const std::move_iterator<_IteratorL>'
   30 |     return upper_bound(stk.rbegin(), stk.rend(), r) - stk.begin();
      |                                                                 ^
In file included from /usr/include/c++/13/ccomplex:39,
                 from /usr/include/x86_64-linux-gnu/c++/13/bits/stdc++.h:127:
/usr/include/c++/13/complex:365:5: note: candidate: 'template<class _Tp> constexpr std::complex<_Tp> std::operator-(const complex<_Tp>&, const complex<_Tp>&)'
  365 |     operator-(const complex<_Tp>& __x, const complex<_Tp>& __y)
      |     ^~~~~~~~
/usr/include/c++/13/complex:365:5: note:   template argument deduction/substitution failed:
election.cpp:30:65: note:   'std::reverse_iterator<__gnu_cxx::__normal_iterator<long long int*, std::vector<long long int> > >' is not derived from 'const std::complex<_Tp>'
   30 |     return upper_bound(stk.rbegin(), stk.rend(), r) - stk.begin();
      |                                                                 ^
/usr/include/c++/13/complex:374:5: note: candidate: 'template<class _Tp> constexpr std::complex<_Tp> std::operator-(const complex<_Tp>&, const _Tp&)'
  374 |     operator-(const complex<_Tp>& __x, const _Tp& __y)
      |     ^~~~~~~~
/usr/include/c++/13/complex:374:5: note:   template argument deduction/substitution failed:
election.cpp:30:65: note:   'std::reverse_iterator<__gnu_cxx::__normal_iterator<long long int*, std::vector<long long int> > >' is not derived from 'const std::complex<_Tp>'
   30 |     return upper_bound(stk.rbegin(), stk.rend(), r) - stk.begin();
      |                                                                 ^
/usr/include/c++/13/complex:383:5: note: candidate: 'template<class _Tp> constexpr std::complex<_Tp> std::operator-(const _Tp&, const complex<_Tp>&)'
  383 |     operator-(const _Tp& __x, const complex<_Tp>& __y)
      |     ^~~~~~~~
/usr/include/c++/13/complex:383:5: note:   template argument deduction/substitution failed:
election.cpp:30:65: note:   'std::vector<long long int>::iterator' is not derived from 'const std::complex<_Tp>'
   30 |     return upper_bound(stk.rbegin(), stk.rend(), r) - stk.begin();
      |                                                                 ^
/usr/include/c++/13/complex:460:5: note: candidate: 'template<class _Tp> constexpr std::complex<_Tp> std::operator-(const complex<_Tp>&)'
  460 |     operator-(const complex<_Tp>& __x)
      |     ^~~~~~~~
/usr/include/c++/13/complex:460:5: note:   template argument deduction/substitution failed:
election.cpp:30:65: note:   'std::reverse_iterator<__gnu_cxx::__normal_iterator<long long int*, std::vector<long long int> > >' is not derived from 'const std::complex<_Tp>'
   30 |     return upper_bound(stk.rbegin(), stk.rend(), r) - stk.begin();
      |                                                                 ^
In file included from /usr/include/c++/13/valarray:605,
                 from /usr/include/x86_64-linux-gnu/c++/13/bits/stdc++.h:166:
/usr/include/c++/13/bits/valarray_after.h:406:5: note: candidate: 'template<class _Dom1, class _Dom2> std::_Expr<std::__detail::_BinClos<std::__minus, std::_Expr, std::_Expr, _Dom1, _Dom2>, typename std::__fun<std::__minus, typename _Dom1::value_type>::result_type> std::operator-(const _Expr<_Dom1, typename _Dom1::value_type>&, const _Expr<_Dom2, typename _Dom2::value_type>&)'
  406 |     _DEFINE_EXPR_BINARY_OPERATOR(-, struct std::__minus)
      |     ^~~~~~~~~~~~~~~~~~~~~~~~~~~~
/usr/include/c++/13/bits/valarray_after.h:406:5: note:   template argument deduction/substitution failed:
election.cpp:30:65: note:   'std::reverse_iterator<__gnu_cxx::__normal_iterator<long long int*, std::vector<long long int> > >' is not derived from 'const std::_Expr<_Dom1, typename _Dom1::value_type>'
   30 |     return upper_bound(stk.rbegin(), stk.rend(), r) - stk.begin();
      |                                                                 ^
/usr/include/c++/13/bits/valarray_after.h:406:5: note: candidate: 'template<class _Dom> std::_Expr<std::__detail::_BinClos<std::__minus, std::_Expr, std::_Constant, _Dom, typename _Dom::value_type>, typename std::__fun<std::__minus, typename _Dom1::value_type>::result_type> std::operator-(const _Expr<_Dom1, typename _Dom1::value_type>&, const typename _Dom::value_type&)'
  406 |     _DEFINE_EXPR_BINARY_OPERATOR(-, struct std::__minus)
      |     ^~~~~~~~~~~~~~~~~~~~~~~~~~~~
/usr/include/c++/13/bits/valarray_after.h:406:5: note:   template argument deduction/substitution failed:
election.cpp:30:65: note:   'std::reverse_iterator<__gnu_cxx::__normal_iterator<long long int*, std::vector<long long int> > >' is not derived from 'const std::_Expr<_Dom1, typename _Dom1::value_type>'
   30 |     return upper_bound(stk.rbegin(), stk.rend(), r) - stk.begin();
      |                                                                 ^
/usr/include/c++/13/bits/valarray_after.h:406:5: note: candidate: 'template<class _Dom> std::_Expr<std::__detail::_BinClos<std::__minus, std::_Constant, std::_Expr, typename _Dom::value_type, _Dom>, typename std::__fun<std::__minus, typename _Dom1::value_type>::result_type> std::operator-(const typename _Dom::value_type&, const _Expr<_Dom1, typename _Dom1::value_type>&)'
  406 |     _DEFINE_EXPR_BINARY_OPERATOR(-, struct std::__minus)
      |     ^~~~~~~~~~~~~~~~~~~~~~~~~~~~
/usr/include/c++/13/bits/valarray_after.h:406:5: note:   template argument deduction/substitution failed:
election.cpp:30:65: note:   'std::vector<long long int>::iterator' is not derived from 'const std::_Expr<_Dom1, typename _Dom1::value_type>'
   30 |     return upper_bound(stk.rbegin(), stk.rend(), r) - stk.begin();
      |                                                                 ^
/usr/include/c++/13/bits/valarray_after.h:406:5: note: candidate: 'template<class _Dom> std::_Expr<std::__detail::_BinClos<std::__minus, std::_Expr, std::_ValArray, _Dom, typename _Dom::value_type>, typename std::__fun<std::__minus, typename _Dom1::value_type>::result_type> std::operator-(const _Expr<_Dom1, typename _Dom1::value_type>&, const valarray<typename _Dom::value_type>&)'
  406 |     _DEFINE_EXPR_BINARY_OPERATOR(-, struct std::__minus)
      |     ^~~~~~~~~~~~~~~~~~~~~~~~~~~~
/usr/include/c++/13/bits/valarray_after.h:406:5: note:   template argument deduction/substitution failed:
election.cpp:30:65: note:   'std::reverse_iterator<__gnu_cxx::__normal_iterator<long long int*, std::vector<long long int> > >' is not derived from 'const std::_Expr<_Dom1, typename _Dom1::value_type>'
   30 |     return upper_bound(stk.rbegin(), stk.rend(), r) - stk.begin();
      |                                                                 ^
/usr/include/c++/13/bits/valarray_after.h:406:5: note: candidate: 'template<class _Dom> std::_Expr<std::__detail::_BinClos<std::__minus, std::_ValArray, std::_Expr, typename _Dom::value_type, _Dom>, typename std::__fun<std::__minus, typename _Dom1::value_type>::result_type> std::operator-(const valarray<typename _Dom::value_type>&, const _Expr<_Dom1, typename _Dom1::value_type>&)'
  406 |     _DEFINE_EXPR_BINARY_OPERATOR(-, struct std::__minus)
      |     ^~~~~~~~~~~~~~~~~~~~~~~~~~~~
/usr/include/c++/13/bits/valarray_after.h:406:5: note:   template argument deduction/substitution failed:
election.cpp:30:65: note:   'std::vector<long long int>::iterator' is not derived from 'const std::_Expr<_Dom1, typename _Dom1::value_type>'
   30 |     return upper_bound(stk.rbegin(), stk.rend(), r) - stk.begin();
      |                                                                 ^
/usr/include/c++/13/valarray:1197:1: note: candidate: 'template<class _Tp> std::_Expr<std::__detail::_BinClos<std::__minus, std::_ValArray, std::_ValArray, _Tp, _Tp>, typename std::__fun<std::__minus, _Tp>::result_type> std::operator-(const valarray<_Tp>&, const valarray<_Tp>&)'
 1197 | _DEFINE_BINARY_OPERATOR(-, __minus)
      | ^~~~~~~~~~~~~~~~~~~~~~~
/usr/include/c++/13/valarray:1197:1: note:   template argument deduction/substitution failed:
election.cpp:30:65: note:   'std::reverse_iterator<__gnu_cxx::__normal_iterator<long long int*, std::vector<long long int> > >' is not derived from 'const std::valarray<_Tp>'
   30 |     return upper_bound(stk.rbegin(), stk.rend(), r) - stk.begin();
      |                                                                 ^
/usr/include/c++/13/valarray:1197:1: note: candidate: 'template<class _Tp> std::_Expr<std::__detail::_BinClos<std::__minus, std::_ValArray, std::_Constant, _Tp, _Tp>, typename std::__fun<std::__minus, _Tp>::result_type> std::operator-(const valarray<_Tp>&, const typename valarray<_Tp>::value_type&)'
 1197 | _DEFINE_BINARY_OPERATOR(-, __minus)
      | ^~~~~~~~~~~~~~~~~~~~~~~
/usr/include/c++/13/valarray:1197:1: note:   template argument deduction/substitution failed:
election.cpp:30:65: note:   'std::reverse_iterator<__gnu_cxx::__normal_iterator<long long int*, std::vector<long long int> > >' is not derived from 'const std::valarray<_Tp>'
   30 |     return upper_bound(stk.rbegin(), stk.rend(), r) - stk.begin();
      |                                                                 ^
/usr/include/c++/13/valarray:1197:1: note: candidate: 'template<class _Tp> std::_Expr<std::__detail::_BinClos<std::__minus, std::_Constant, std::_ValArray, _Tp, _Tp>, typename std::__fun<std::__minus, _Tp>::result_type> std::operator-(const typename valarray<_Tp>::value_type&, const valarray<_Tp>&)'
 1197 | _DEFINE_BINARY_OPERATOR(-, __minus)
      | ^~~~~~~~~~~~~~~~~~~~~~~
/usr/include/c++/13/valarray:1197:1: note:   template argument deduction/substitution failed:
election.cpp:30:65: note:   'std::vector<long long int>::iterator' is not derived from 'const std::valarray<_Tp>'
   30 |     return upper_bound(stk.rbegin(), stk.rend(), r) - stk.begin();
      |                                                                 ^
/usr/include/c++/13/bits/stl_iterator.h:1321:5: note: candidate: 'template<class _IteratorL, class _IteratorR, class _Container> constexpr decltype ((__lhs.base() - __rhs.base())) __gnu_cxx::operator-(const __normal_iterator<_IteratorL, _Container>&, const __normal_iterator<_IteratorR, _Container>&)'
 1321 |     operator-(const __normal_iterator<_IteratorL, _Container>& __lhs,
      |     ^~~~~~~~
/usr/include/c++/13/bits/stl_iterator.h:1321:5: note:   template argument deduction/substitution failed:
election.cpp:30:65: note:   'std::reverse_iterator<__gnu_cxx::__normal_iterator<long long int*, std::vector<long long int> > >' is not derived from 'const __gnu_cxx::__normal_iterator<_IteratorL, _Container>'
   30 |     return upper_bound(stk.rbegin(), stk.rend(), r) - stk.begin();
      |                                                                 ^
/usr/include/c++/13/bits/stl_iterator.h:1334:5: note: candidate: 'template<class _Iterator, class _Container> constexpr typename __gnu_cxx::__normal_iterator<_Iterator, _Container>::difference_type __gnu_cxx::operator-(const __normal_iterator<_Iterator, _Container>&, const __normal_iterator<_Iterator, _Container>&)'
 1334 |     operator-(const __normal_iterator<_Iterator, _Container>& __lhs,
      |     ^~~~~~~~
/usr/include/c++/13/bits/stl_iterator.h:1334:5: note:   template argument deduction/substitution failed:
election.cpp:30:65: note:   'std::reverse_iterator<__gnu_cxx::__normal_iterator<long long int*, std::vector<long long int> > >' is not derived from 'const __gnu_cxx::__normal_iterator<_Iterator, _Container>'
   30 |     return upper_bound(stk.rbegin(), stk.rend(), r) - stk.begin();
      |                                                                 ^
election.cpp: In function 'int main()':
election.cpp:110:18: error: 'st' was not declared in this scope; did you mean 'stk'?
  110 |             if (!st.empty()){
      |                  ^~
      |                  stk