From e84b8a5e331253db5a08b6b727db8590d22c7e12 Mon Sep 17 00:00:00 2001 From: TerekhovFV Date: Wed, 24 Apr 2024 04:28:32 +0300 Subject: [PATCH] =?UTF-8?q?work:=20=D1=81=D0=BE=D1=85=D1=80=D0=B0=D0=BD?= =?UTF-8?q?=D0=B5=D0=BD=D0=B8=D0=B5=20=D0=BF=D1=80=D0=BE=D0=B5=D0=BA=D1=82?= =?UTF-8?q?=D0=B0?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --- main.cpp | 78 ++++++++++++++++++++++++++++++++++++++--------------- project.cbp | 11 ++++++++ 2 files changed, 67 insertions(+), 22 deletions(-) diff --git a/main.cpp b/main.cpp index 206a4f7..0972756 100644 --- a/main.cpp +++ b/main.cpp @@ -3,43 +3,63 @@ using namespace std; -int main() -{ - const size_t SCREEN_WIDTH = 80; - const size_t MAX_ASTERISK = SCREEN_WIDTH - 3 - 1; + +struct Input { + vector numbers; size_t bin_count{}; size_t number_count{}; size_t max_count{}; +}; +Input +input_data() { + Input in; cerr << "Enter number count: "; - cin >> number_count; - vector numbers(number_count); - for (size_t i = 0; i < number_count; i++) { - cin >> numbers[i]; - cerr << "Enter bin count: "; - cin >> bin_count; - max_count = 0; + cin >> in.number_count; + + + vector numbers(in.number_count); + in.numbers.resize(in.number_count); + for (size_t i = 0; i < in.number_count; i++) { + cin >> in.numbers[i]; } - size_t mn = numbers[0]; - size_t - mx = numbers[0]; + + size_t bin_count; + cerr << "Enter bin count: "; + cin >> in.bin_count; + + size_t max_count; + in.max_count = 0; + return in; +} + +void +find_minmax(const vector& numbers, double& min, double& max) { + min = numbers[0]; + max = numbers[0]; for (double x : numbers) { - if (x < mn){ - mn = x; + if (x < min){ + min = x; } - else if (x > mx){ - mx = x; + else if (x > max){ + max = x; } } - double bin_size = (mx - mn) / bin_count; +} + +vector +make_histogram(const vector& numbers, size_t & bin_count, size_t & number_count, size_t & max_count) { + double min, max; + find_minmax(numbers, min, max); + double bin_size = (max - min) / bin_count; vector bins(bin_count); max_count = bins[0]; for (size_t i = 0; i < number_count; i++){ bool found = false; for (size_t j = 0; (j < bin_count - 1) && !found; j++){ - auto lo = mn + j * bin_size; - auto hi = mn + (j + 1) * bin_size; + auto lo = min + j * bin_size; + auto hi = min + (j + 1) * bin_size; if ((lo <= numbers[i]) && (numbers[i] < hi)){ bins[j]++; found = true; @@ -55,7 +75,14 @@ int main() max_count = bins[bin_count - 1]; } } - if (max_count > MAX_ASTERISK){ + return bins; +} + +void +show_histogram_text(vector& bins, size_t & max_count,size_t & bin_count){ +const size_t SCREEN_WIDTH = 80; +const size_t MAX_ASTERISK = SCREEN_WIDTH - 3 - 1; +if (max_count > MAX_ASTERISK){ vector hights(bin_count); for (size_t i = 0; i < bin_count; i++){ size_t height = MAX_ASTERISK * (static_cast(bins[i]) / max_count); @@ -80,4 +107,11 @@ int main() cout << endl; } } + +} +int main() +{ + auto in = input_data(); + auto bins = make_histogram(in.numbers, in.bin_count, in.number_count, in.max_count); + show_histogram_text(bins, in.max_count, in.bin_count); } diff --git a/project.cbp b/project.cbp index 34f06bc..faf8eec 100644 --- a/project.cbp +++ b/project.cbp @@ -33,7 +33,18 @@ + + + + + + + +