#include #include #include #include #include using namespace std; //Создание структуры Input для входных данных struct Input { vector Numbers; size_t bin_count{}; }; //Функция ввода Input input_data(){ size_t number_count; Input stct; //Ввод количества элементов массива cerr << "Enter number count "; cin >> number_count; //Ввод массива vector Numbers(number_count); stct.Numbers.resize(number_count); cerr << "Enter array:\n"; cin >> Numbers[0]; for (int i = 1; i < number_count; i++) { cin >> stct.Numbers[i]; } //Ввод количества корзин cerr << "Enter bin count\n"; cin >> stct.bin_count; //Возвращаем структуру return stct; } //Функция поиска минимума и максиммума void find_minmax(const vector& numbers, double& Min, double& Max){ Min = numbers[0]; Max = numbers[0]; for (int i = 1; i < numbers.size(); i++) { if (numbers[i] > Max) Max = numbers[i]; if (numbers[i] < Min) Min = numbers[i]; } } //Функция расчёта гистограммы vector make_histogram(const vector& Numbers, size_t bin_count){ //Определение шага между корзинами double Max, Min; find_minmax(Numbers, Min, Max); double bin_size = (Max-Min) / bin_count; //Массив корзин vector bins(bin_count); for (size_t i = 0; i < bin_count; i++) // обнуление корзин bins[i] = 0; for (size_t i = 0; i < bin_count; i++) { double lo = Min + i * bin_size; double hi = Min + (i + 1) * bin_size; for (size_t j = 0; j < Numbers.size(); j++) { if (lo <= Numbers[j] && Numbers[j] <= hi) bins[i]++; } } return bins; } //Функция отображения и масштабирования гистограммы void show_histogram_text(const vector& bins){ const size_t SCREEN_WIDTH = 80; const size_t MAX_ASTERISK = SCREEN_WIDTH - 3 - 3; //Проверка необходимости масшатбирования size_t max4scale = 0; for (size_t x : bins){ if (x > max4scale){ max4scale = x; } } if (max4scale > MAX_ASTERISK){ for (size_t x : bins) { if (x >= 100){ cout << x << " | "; } else if (x >= 10){ cout << " " << x << " | "; } else{ cout << " " << x << " | "; } size_t count = x; size_t height = MAX_ASTERISK * (static_cast(count) / max4scale); for (size_t i = 0; i < height; i++) { cout << "*"; } cout << "\n"; } } else{ //Вывод for (size_t x : bins) { if (x >= 100){ cout << x << " | "; } else if (x >= 10){ cout << " " << x << " | "; } else{ cout << " " << x << " | "; } for (size_t i = 0; i < x; i++) { cout << "*"; } cout << "\n"; } } return; } int main() { //Ввод массива и количества корзин Input in = input_data(); //Определение минимума и максимума double max, min; find_minmax(in.Numbers, min, max); //Создание вектора bins для гистограммы vector bins = make_histogram(in.Numbers, in.bin_count); // show_histogram_text(bins); return 0; }