#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; }