From 778de65823cfe674a9bafebd5c9901b936f9e4f9 Mon Sep 17 00:00:00 2001 From: KuybedaAY Date: Thu, 24 Apr 2025 22:52:18 +0300 Subject: [PATCH] =?UTF-8?q?=D0=B8=D1=81=D1=85=D0=BE=D0=B4=D0=BD=D0=B8?= =?UTF-8?q?=D0=BA?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --- lab1.cbp | 40 ++++++++++++++++++++ main.cpp | 113 +++++++++++++++++++++++++++++++++++++++++++++++++++++++ 2 files changed, 153 insertions(+) create mode 100644 lab1.cbp create mode 100644 main.cpp diff --git a/lab1.cbp b/lab1.cbp new file mode 100644 index 0000000..a01ffa6 --- /dev/null +++ b/lab1.cbp @@ -0,0 +1,40 @@ + + + + + + diff --git a/main.cpp b/main.cpp new file mode 100644 index 0000000..95fa6db --- /dev/null +++ b/main.cpp @@ -0,0 +1,113 @@ +#include +#include +#include + +using namespace std; + +const size_t SCREEN_WIDTH = 80; +const size_t MAX_ASTERISK = SCREEN_WIDTH - 3 - 1; + +int main() { + + size_t number_count; + cerr << "Enter number count: "; + cin >> number_count; + + + vector numbers(number_count); + cerr << "Enter " << number_count << " numbers: "; + for (size_t i = 0; i < number_count; i++) { + cin >> numbers[i]; + } + + size_t bin_count; + cerr << "Enter bin count: "; + cin >> bin_count; + + + double min = numeric_limits::max(); + double max = numeric_limits::lowest(); + + for (double x : numbers) { + if (x < min) { + min = x; + } + if (x > max) { + max = x; + } + } + + + double bin_size = (max - min) / bin_count; + + + vector bins(bin_count, 0); + + + for (size_t i = 0; i < numbers.size(); i++) { + bool found = false; + for (size_t j = 0; (j < bin_count - 1) && !found; j++) { + double lo = min + j * bin_size; + double hi = min + (j + 1) * bin_size; + if ((lo <= numbers[i]) && (numbers[i] < hi)) { + bins[j]++; + found = true; + } + } + + if (!found) { + bins[bin_count - 1]++; + } + } + + size_t max_count = 0; + for (size_t count : bins) { + if (count > max_count) { + max_count = count; + } + } + + + cerr << "Bin counts:" << endl; + + + + + + + + + + + + + + size_t height; + for (size_t j = 0; j < bin_count; j++) { + // Вычисляем высоту гистограммы + if(max_count > 76){ + height = (max_count > 0) ? static_cast(76 * (static_cast(bins[j]) / max_count)) : 0; + } + else{ + height = bins[j]; + } + // Выводим количество в бине с учетом форматирования + if (bins[j] < 10) { + cout << " " << bins[j] << "|"; + } else if (bins[j] < 100) { + cout << " " << bins[j] << "|"; + } else { + cout << bins[j] << "|"; + } + + // Выводим символы '*' в соответствии с высотой + for (size_t k = 0; k < height; k++) { + cout << "*"; + } + cout << endl; + } + + return 0; +} + +