From 8761ff5730816fe592cdb50f92b301c201aae6d9 Mon Sep 17 00:00:00 2001 From: Artem <TurkhanovAK@mpei.ru> Date: Fri, 19 Apr 2024 22:17:24 +0300 Subject: [PATCH] =?UTF-8?q?cbuild:=20=D0=BF=D1=80=D0=BE=D0=B3=D1=80=D0=B0?= =?UTF-8?q?=D0=BC=D0=BC=D0=B0=20=D1=80=D0=B0=D0=B7=D0=B4=D0=B5=D0=BB=D0=B5?= =?UTF-8?q?=D0=BD=D0=B0=20=D0=BD=D0=B0=20=D1=84=D0=B0=D0=B9=D0=BB=D1=8B?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --- histogram.cpp | 44 ++++++++++++++++++++++++++++++++++++++++++++ histogram.h | 9 +++++++++ main.cpp | 44 ++------------------------------------------ 3 files changed, 55 insertions(+), 42 deletions(-) create mode 100644 histogram.cpp create mode 100644 histogram.h diff --git a/histogram.cpp b/histogram.cpp new file mode 100644 index 0000000..fa1de22 --- /dev/null +++ b/histogram.cpp @@ -0,0 +1,44 @@ +#include "histogram.h" + +static void +find_minmax(const std::vector<double>& numbers, double& min, double& max){ + min = numbers[0]; + max = numbers[0]; + + for (double x : numbers) { + if (x < min) { + min = x; + } + else if (x > max) { + max = x; + } + } +} + + +std::vector<size_t> +make_histogram(const std::vector<double>& numbers, size_t bin_count){ + + std::vector<size_t> 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; +} diff --git a/histogram.h b/histogram.h new file mode 100644 index 0000000..0d8dc8c --- /dev/null +++ b/histogram.h @@ -0,0 +1,9 @@ +#ifndef HISTOGRAM_H_INCLUDED +#define HISTOGRAM_H_INCLUDED + +#include <vector> + +std::vector<size_t> +make_histogram(const std::vector<double>& numbers, size_t bin_count); + +#endif // HISTOGRAM_H_INCLUDED diff --git a/main.cpp b/main.cpp index f117ecb..58e6ee2 100644 --- a/main.cpp +++ b/main.cpp @@ -1,5 +1,6 @@ #include <iostream> #include <vector> +#include "histogram.h" const size_t SCREEN_WIDTH = 80; const size_t MAX_ASTERISK = SCREEN_WIDTH - 3 - 1; @@ -32,48 +33,7 @@ input_data(){ } void -find_minmax(vector<double>& numbers, double& min, double& max){ - min = numbers[0]; - max = numbers[0]; - - for (double x : numbers) { - if (x < min) { - min = x; - } - else if (x > max) { - max = x; - } - } -} - - -vector<size_t> make_histogram(vector<double>& numbers, size_t bin_count){ - - vector<size_t> 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; -} - -void show_histogram_text(vector<size_t>& bins){ +show_histogram_text(vector<size_t>& bins){ size_t max_count = 0; for (size_t x: bins) {