TakahiroNakamori

TakahiroNakamori

ナカモリタカヒロ

 
 

Range Count Query

問題

D – Range Count Query
プログラミング初級者から上級者まで楽しめる、競技プログラミングコンテストサイト「AtCoder」。オンラインで毎週開催プログラミングコンテストを開催しています。競技…

記録

解法

コード例

#include <bits/stdc++.h>
using namespace std;
#include <atcoder/all>
using namespace atcoder;
using ll = long long;
using P = pair<int, int>;
#define rep(i, n) for(int i = 0; i < (n); ++i)
// using mint = modint998244353;
// using mint = modint1000000007;
// const int mod = 1000000007;
// const ll INF = 1LL << 62;
// const int INF = 1001001001;

int main() {
  int N;
  cin >> N;

  vector<int> A(N);
  vector<vector<int>> v(200010);
  rep(i,N) {
    cin >> A[i];
    v[A[i]].push_back(i);
  }

  int Q;
  cin >> Q;
  while(0 < Q) {
    int L, R, X;
    cin >> L >> R >> X;
    if (v[X].size() == 0) {
      cout << 0 << endl;
    } else {
      int ans = lower_bound(v[X].begin(), v[X].end(), R) - lower_bound(v[X].begin(), v[X].end(), L-1);
      cout << ans << endl;
    }
    Q--;
  }

  return 0;
}