結果
問題 |
No.2710 How many more?
|
ユーザー |
|
提出日時 | 2024-03-31 20:12:59 |
言語 | C++14 (gcc 13.3.0 + boost 1.87.0) |
結果 |
WA
|
実行時間 | - |
コード長 | 628 bytes |
コンパイル時間 | 1,902 ms |
コンパイル使用メモリ | 181,612 KB |
実行使用メモリ | 8,784 KB |
最終ジャッジ日時 | 2024-09-30 21:20:48 |
合計ジャッジ時間 | 6,042 ms |
ジャッジサーバーID (参考情報) |
judge1 / judge4 |
(要ログイン)
ファイルパターン | 結果 |
---|---|
sample | AC * 2 |
other | AC * 5 WA * 12 |
ソースコード
#include <bits/stdc++.h> using namespace std; int main(){ int N, Q; cin >> N >> Q; vector<pair<int, int>> A; for (int i=0; i<N; ++i){ int a; cin>>a; A.push_back(make_pair(a, i+1)); } sort(A.begin(), A.end()); map<int,int> A_; int rank=1; for (int i=0;i<N-1;++i){ A_[A[i].second]=rank; if ((A[i].first!=A[i+1].first)){++rank;} } A_[A[N-1].second]=rank; for (int _=0; _<Q; ++_){ int x, y; cin >> x >> y; int ans = A_[x]-A_[y]-1; if ((ans)>=0){cout << ans << endl;} else {cout<<0<<endl;} } }