結果
問題 | No.2374 ASKT Subsequences |
ユーザー | srjywrdnprkt |
提出日時 | 2023-07-07 22:37:32 |
言語 | C++17(gcc12) (gcc 12.3.0 + boost 1.87.0) |
結果 |
AC
|
実行時間 | 53 ms / 2,000 ms |
コード長 | 707 bytes |
コンパイル時間 | 2,556 ms |
コンパイル使用メモリ | 205,052 KB |
実行使用メモリ | 34,816 KB |
最終ジャッジ日時 | 2024-07-21 18:50:42 |
合計ジャッジ時間 | 4,207 ms |
ジャッジサーバーID (参考情報) |
judge1 / judge4 |
(要ログイン)
ファイルパターン | 結果 |
---|---|
sample | AC * 3 |
other | AC * 28 |
ソースコード
#include <bits/stdc++.h> using namespace std; using ll = long long; int main(){ ll N, ans=0; cin >> N; vector<int> A(N+1); vector<vector<int>> S(N+1, vector<int>(2001)), T(N+2, vector<int>(2001)); for (int i=1; i<=N; i++){ cin >> A[i]; S[i][A[i]]++; T[i][A[i]]++; } for (int i=1; i<=N; i++) for (int j=0; j<=2000; j++) S[i][j] += S[i-1][j]; for (int i=N; i>=1; i--) for (int j=0; j<=2000; j++) T[i][j] += T[i+1][j]; for (int i=1; i<=N; i++){ for (int j=i+1; j<=N; j++){ if (A[j]-10>=0 && A[i]+1<=2000 && A[i]-A[j] >= 1) ans += S[i-1][A[j]-10] * T[j+1][A[i]+1]; } } cout << ans << endl; return 0; }