#include template 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 Array initArray(int n) { Array res; res.p = new T [n + 3]; res.size = n; res.seek = 0; return res; } template Array loadArray(int n) { Array res = initArray(n); for(int i = 0; i < n; ++i) { scanf("%d", &res[i]); } return res; } template T head(Array xs) { return xs[0]; } template T last(Array xs) { return xs[xs.size-1]; } template Array tail(Array xs) { return Array(xs.p, xs.size - 1, xs.seek + 1); } template Array init(Array xs) { return Array(xs.p, xs.size - 1, xs.seek); } template U mean(Array xs) { U res = 0; int n = xs.size; for(int i = 0; i < n; ++i) { res += xs[i]; } return res / n; } template Array sort(Array xs) { Array res = initArray(xs.size); for(int i = 0; i < xs.size; ++i) { res[i] = xs[i]; } std::sort(res.p, res.p + res.size); return res; } int main() { Array xs = loadArray(6); double res = mean(init(tail(sort(xs)))); printf("%.2lf\n", res); return 0; }