結果
| 問題 |
No.2956 Substitute with Average
|
| コンテスト | |
| ユーザー |
startcpp
|
| 提出日時 | 2024-10-23 23:30:13 |
| 言語 | C++14 (gcc 13.3.0 + boost 1.87.0) |
| 結果 |
RE
|
| 実行時間 | - |
| コード長 | 715 bytes |
| コンパイル時間 | 870 ms |
| コンパイル使用メモリ | 80,252 KB |
| 実行使用メモリ | 6,824 KB |
| 最終ジャッジ日時 | 2024-10-25 19:45:19 |
| 合計ジャッジ時間 | 3,570 ms |
|
ジャッジサーバーID (参考情報) |
judge3 / judge5 |
(要ログイン)
| ファイルパターン | 結果 |
|---|---|
| sample | AC * 3 |
| other | AC * 7 RE * 18 |
ソースコード
//小さなケースを全探索して正しいかを検証
//浮動小数点数の誤差があってWAになる可能性はあるかも
#include <iostream>
#include <vector>
#include <set>
#include <cassert>
#define rep(i, n) for(i = 0; i < n; i++)
using namespace std;
int main() {
int n;
int a[300];
cin >> n;
assert(n <= 300);
int i, j, k;
rep(i, n) cin >> a[i];
set<vector<double>> st;
rep(i, n) {
for (j = i; j < n; j++) {
double ave = 0;
for (k = i; k <= j; k++) ave += a[k];
ave /= (double)(j - i + 1);
vector<double> b;
rep(k, n) {
if (i <= k && k <= j) b.push_back(ave);
else b.push_back(a[k]);
}
st.insert(b);
}
}
cout << st.size() << endl;
return 0;
}
startcpp