50 lines
1.2 KiB
C
50 lines
1.2 KiB
C
|
/*
|
||
|
* Created by Brett on 28/02/23.
|
||
|
* Licensed under GNU General Public License V3.0
|
||
|
* See LICENSE file for license detail
|
||
|
*/
|
||
|
|
||
|
#ifndef BLT_TESTS_AVERAGES_H
|
||
|
#define BLT_TESTS_AVERAGES_H
|
||
|
|
||
|
namespace blt {
|
||
|
|
||
|
template<typename T, int Size>
|
||
|
class averagizer_o_matic {
|
||
|
private:
|
||
|
T* data;
|
||
|
int index = 0;
|
||
|
int m_default = 0;
|
||
|
public:
|
||
|
averagizer_o_matic(): averagizer_o_matic(0) {}
|
||
|
explicit averagizer_o_matic(T default_value){
|
||
|
data = new T[Size];
|
||
|
for (int i = 0; i < Size; i++){
|
||
|
data[i] = default_value;
|
||
|
}
|
||
|
m_default = default_value;
|
||
|
}
|
||
|
|
||
|
void insert(T t){
|
||
|
data[index++] = t;
|
||
|
if (index >= Size)
|
||
|
index = 0;
|
||
|
}
|
||
|
|
||
|
T average(){
|
||
|
T total = 0;
|
||
|
for (int i = 0; i < Size; i++){
|
||
|
total += data[i];
|
||
|
}
|
||
|
return total / Size;
|
||
|
}
|
||
|
|
||
|
~averagizer_o_matic(){
|
||
|
delete[] data;
|
||
|
}
|
||
|
};
|
||
|
|
||
|
}
|
||
|
|
||
|
#endif //BLT_TESTS_AVERAGES_H
|