diff --git a/main.cpp b/main.cpp index 2c3f59f..c723e41 100644 --- a/main.cpp +++ b/main.cpp @@ -4,28 +4,29 @@ using namespace std; -int main() -{ - int i, j; - size_t number_count; - const size_t screen_width = 80; - const size_t max_asterisk = screen_width - 3 - 1; +struct Input { + vector numbers; + size_t bin_count{}; +}; - cerr << "Enter number count : "; +Input +input_data() { + size_t number_count; cin >> number_count; - vector numbers(number_count); - cerr << "Enter numbers : " << endl; - for (i = 0; i < number_count; i++) - { - cin >> numbers[i]; + Input in; + in.numbers.resize(number_count); + for (size_t i = 0; i < number_count; i++) { + cin >> in.numbers[i]; } - size_t bin_count; - cerr << "Enter bin count : "; - cin >> bin_count; - vector bins(bin_count); + cerr<< "Enter bin count: "; + cin >> in.bin_count; + return in; +} - double min = numbers[0]; - double max = numbers[0]; +void +find_minmax(vector &numbers, double& min, double& max) { + min = numbers[0]; + max = numbers[0]; for (double x : numbers) { if (x < min) @@ -37,10 +38,16 @@ int main() max = x; } } - + return; +} +vector make_histogram (vector numbers, size_t bin_count) +{ + double min; + double max; + find_minmax (numbers, min, max); double bin_size = (max - min) / bin_count; - - for (size_t i = 0; i < number_count; i++) + vector bins(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++) @@ -49,7 +56,7 @@ int main() auto hi = min + (j + 1) * bin_size; if ((lo <= numbers[i]) && (numbers[i] < hi)) { - bins[j] ++; + bins[j]++; found = true; } } @@ -58,11 +65,18 @@ int main() bins[bin_count - 1]++; } } + return bins; +} +void show_histogram_text(vector bins, size_t bin_count) +{ + const size_t screen_width = 80; + const size_t max_asterisk = screen_width - 3 - 1; + size_t i,j; double max_count; max_count = bins[0]; for (i=0; i< bin_count; i++) - { + { if (max_count