diff --git a/histogram.cpp b/histogram.cpp deleted file mode 100644 index 109a2f8..0000000 --- a/histogram.cpp +++ /dev/null @@ -1,52 +0,0 @@ -#include "histogram.h" - -bool -find_minmax(const std::vector& numbers, double& min, double& max){ - if (numbers.size() != 0) { - min = numbers[0]; - max = numbers[0]; - - for (double x : numbers) { - if (x < min) { - min = x; - } - else if (x > max) { - max = x; - } - } - return true; - } - - else { - return false; - } - -} - - -std::vector -make_histogram(const std::vector& numbers, size_t bin_count){ - - std::vector bins(bin_count); - - double min, max; - find_minmax(numbers, min, max); - - double bin_size = (max - min) / bin_count; - - for (size_t i = 0; i < numbers.size(); i++) { - bool found = false; // текущее состояние текущего элемента. Элемент не распределен в корзину - for (size_t j = 0; (j < bin_count - 1) && !found; j++) { // берём j-ю корзину - auto lo = min + j * bin_size; // определяем границы данной корзины - auto hi = min + (j + 1) * bin_size; - if ((lo <= numbers[i]) && (numbers[i] < hi)) { // подставляем под эти границы i-й элемент из numbers - bins[j]++; // если элемент находится в данном диапазоне (границах), то увеличиваем счетчик j-ой корзины - found = true; // переключаем "флажок", чтобы прекратить перебор корзин и перейти к сдед. эл. из numbers - } // то есть теперь элемент распределен в корзину и нет нужды перебирать остальные корзины - } - if (!found) { // а если же всё таки эл. не распределен, то это значит, что он попадает в последний диапазон - bins[bin_count - 1]++; // добавляем этот эл. в последнюю корзину - } - } - return bins; -}