From 835c303712db07053ae41a55d824b9ea58297190 Mon Sep 17 00:00:00 2001 From: artemzelenov Date: Fri, 21 Apr 2023 18:53:59 +0300 Subject: [PATCH] =?UTF-8?q?code:=20=D0=B8=D0=B7=D0=BC=D0=B5=D0=BD=D0=B5?= =?UTF-8?q?=D0=BD=D0=B8=D0=B5=20=D0=BA=D0=BE=D0=B4=D0=B0=20=D0=B4=D0=BE=20?= =?UTF-8?q?=D0=BF=D1=83=D0=BD=D0=BA=D1=82=D0=B0=204?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --- project/main.cpp | 61 ++++++++++++++++++++++++++++++++---------------- 1 file changed, 41 insertions(+), 20 deletions(-) diff --git a/project/main.cpp b/project/main.cpp index 4970112..7fe5010 100644 --- a/project/main.cpp +++ b/project/main.cpp @@ -5,22 +5,31 @@ using namespace std; const size_t SCREEN_WIDTH = 80; const size_t MAX_ASTERISK = SCREEN_WIDTH - 3 - 1; -int main() -{ +struct Input { + vector numbers; + size_t bin_count{}; +}; + +Input +input_data(){ size_t number_count; - size_t bin_count; cerr << "Enter number count: "; cin >> number_count; - vector numbers(number_count); + Input in; + in.numbers.resize(number_count); for(int i;i> numbers[i]; + cin >> in.numbers[i]; } cerr << "Enter bin count: "; - cin >> bin_count; - vector bins(bin_count); - double min = numbers[0]; - double max = numbers[0]; + cin >> in.bin_count; + return in; +} + +void +find_minmax(vector numbers, double& min, double& max) { + min = numbers[0]; + max = numbers[0]; for (double x : numbers) { if (x < min) { min = x; @@ -29,10 +38,16 @@ int main() max = x; } } +} + +vector +make_histogram(vector numbers, size_t bin_count) { + vector bins(bin_count); + double min, max; + find_minmax(numbers, min, max); size_t countt; - size_t max_count = 0; double bin_size = (max - min) / bin_count; - for (size_t i = 0; i < number_count; i++) { + for (size_t i = 0; i < numbers.size(); i++) { bool found = false; for (size_t j = 0; (j < bin_count - 1) && !found; j++) { auto lo = min + j * bin_size; @@ -46,11 +61,18 @@ int main() bins[bin_count - 1]++; } } + return bins; + + +} + +void +show_histogram_text(auto bins, size_t bin_count){ + size_t max_count = 0; for (size_t i = 0; i < bin_count; i++){ if(bins[i]>max_count) max_count = bins[i]; - - } + } size_t height; for (size_t i = 0; i < bin_count; i++) { @@ -77,13 +99,12 @@ int main() } +} - - - -return 0; - - - +int main() +{ Input in = input_data(); + auto bins = make_histogram(in.numbers, in.bin_count); + show_histogram_text(bins, in.bin_count); + return 0; }