結果
| 問題 | No.3456 Common Difference is D |
| コンテスト | |
| ユーザー |
U10
|
| 提出日時 | 2026-02-28 15:33:30 |
| 言語 | C++23 (gcc 15.2.0 + boost 1.89.0) |
| 結果 |
RE
|
| 実行時間 | - |
| コード長 | 1,177 bytes |
| 記録 | |
| コンパイル時間 | 1,732 ms |
| コンパイル使用メモリ | 166,856 KB |
| 実行使用メモリ | 180,836 KB |
| 最終ジャッジ日時 | 2026-02-28 15:33:35 |
| 合計ジャッジ時間 | 5,051 ms |
|
ジャッジサーバーID (参考情報) |
judge3 / judge4 |
(要ログイン)
| ファイルパターン | 結果 |
|---|---|
| sample | AC * 2 |
| other | AC * 10 RE * 10 |
ソースコード
#include <iostream>
#include <vector>
#include <algorithm>
#include <string>
using namespace std;
long long int make_and_count(long long int array[], int n, long long int d) {
long long int count = 0;
long long int table[n][n]={},table2[n][n]={};
for(long long int i=0;i<n;i++) {
for(long long int j=i+1;j<n;j++) {
if(array[j] - array[i] == d) {
table[i][j] = table[i][j-1] + 1;
} else {
table[i][j] = table[i][j-1];
}
}
}
for(long long int j=n-1;j>=0;j--) {
for(long long int i=j-1;i>=0;i--) {
if(array[j] - array[i] == d) {
table2[i][j] = table2[i+1][j] + 1;
} else {
table2[i][j] = table2[i+1][j];
}
}
}
for(long long int i=0;i<n;i++) {
count += table2[0][i] * table[i][n-1];
}
return count;
}
int main(){
long long int n;
long long int d;
cin >> n >> d;
long long int array[n];
for(long long int i=0;i<n;i++) cin >> array[i];
long long int count = make_and_count(array, n, d);
cout << count << endl;
return 0;
}
U10