結果
| 問題 |
No.394 ハーフパイプ(1)
|
| コンテスト | |
| ユーザー |
alpha_virginis
|
| 提出日時 | 2016-07-16 13:12:16 |
| 言語 | C++14 (gcc 13.3.0 + boost 1.87.0) |
| 結果 |
AC
|
| 実行時間 | 2 ms / 2,000 ms |
| コード長 | 1,455 bytes |
| コンパイル時間 | 2,426 ms |
| コンパイル使用メモリ | 168,820 KB |
| 実行使用メモリ | 5,248 KB |
| 最終ジャッジ日時 | 2024-10-15 13:43:16 |
| 合計ジャッジ時間 | 1,896 ms |
|
ジャッジサーバーID (参考情報) |
judge5 / judge4 |
(要ログイン)
| ファイルパターン | 結果 |
|---|---|
| other | AC * 11 |
ソースコード
#include <bits/stdc++.h>
#ifdef CHECK_
int main() {
Array<int> xs = loadArray<int>(6);
double res = mean<double>(init(tail(sort(xs))));
printf("%.2lf\n", res);
return 0;
}
#else
template<typename T>
class Array {
public:
Array() {}
Array(T* p_, int size_, int seek_) : p(p_), size(size_), seek(seek_) {}
T *p;
int size;
int seek;
T& operator [] (int y) {
return p[seek+y];
}
};
template<typename T>
Array<T> initArray(int n) {
Array<T> res;
res.p = new T [n + 3];
res.size = n;
res.seek = 0;
return res;
}
template<typename T>
Array<T> loadArray(int n) {
Array<T> res = initArray<T>(n);
for(int i = 0; i < n; ++i) {
scanf("%d", &res[i]);
}
return res;
}
template<typename T>
T head(Array<T> xs) {
return xs[0];
}
template<typename T>
T last(Array<T> xs) {
return xs[xs.size-1];
}
template<typename T>
Array<T> tail(Array<T> xs) {
return Array<T>(xs.p, xs.size - 1, xs.seek + 1);
}
template<typename T>
Array<T> init(Array<T> xs) {
return Array<T>(xs.p, xs.size - 1, xs.seek);
}
template<typename U, typename T>
U mean(Array<T> xs) {
U res = 0;
int n = xs.size;
for(int i = 0; i < n; ++i) {
res += xs[i];
}
return res / n;
}
template<typename T>
Array<T> sort(Array<T> xs) {
Array<T> res = initArray<T>(xs.size);
for(int i = 0; i < xs.size; ++i) {
res[i] = xs[i];
}
std::sort(res.p, res.p + res.size);
return res;
}
#define CHECK_
#include __FILE__
#endif
alpha_virginis