From 70f742f6e46c268013f43cd0b8a719b4ee098b86 Mon Sep 17 00:00:00 2001
From: KozlovDanD <KozlovDanD@mpei.ru>
Date: Sun, 25 May 2025 20:43:48 +0300
Subject: [PATCH] =?UTF-8?q?code:=20=D1=80=D0=B0=D0=B7=D0=B1=D0=B8=D0=BB=20?=
 =?UTF-8?q?=D0=BA=D0=BE=D0=B4=20=D0=BD=D0=B0=20=D1=84=D1=83=D0=BD=D0=BA?=
 =?UTF-8?q?=D1=86=D0=B8=D0=B8?=
MIME-Version: 1.0
Content-Type: text/plain; charset=UTF-8
Content-Transfer-Encoding: 8bit

---
 main.cpp | 212 ++++++++++++++++++++++++-------------------------------
 1 file changed, 91 insertions(+), 121 deletions(-)

diff --git a/main.cpp b/main.cpp
index aaa7716..c14a7a7 100644
--- a/main.cpp
+++ b/main.cpp
@@ -1,167 +1,137 @@
-/*����� ����� ���������� ����� ����������� ������������ ������������ ��.
-��� ������������� ������ ��������� �������� ������ ��� ������ ������� rand(): ������ ������� ������ ���� ������ 12 �� �����������.
-
-��������. � ������ ��������� �������� srand(time(0)), ����� ��������� ����� ���������� ����� ��������� ��������� (������ Randomize() � Pascal).
-��� ����������� ���������� ������ �������� time(0) �� 42.*/
-#include <time.h>
 #include <iostream>
 #include <vector>
 #include <cstdlib>
 using namespace std;
-
-int main()
+struct Input
 {
+    vector<double> numbers;
+    size_t bin_count{};
+};
 
-    //# ���������� + ������ ���������(�����)
-    const size_t SCREEN_WIDTH = 80;
-    const size_t MAX_ASTERISK = SCREEN_WIDTH - 3 - 1;
-
-    size_t number_count, bin_count, max_count = 0;
-
+Input
+input_data()
+{
+    Input in;
+    size_t number_count;
     cerr << "Enter number count: ";
     cin >> number_count;
 
+    in.numbers.resize(number_count);
     vector<double> numbers(number_count);
 
-    char gen_num;
-
-    cerr << "randoma want? (y/n): ";
-    cin >> gen_num;
-
-    if (gen_num == 'y')
+    for (size_t i = 0; i < number_count; i++)
     {
-        //srand(42);
-        srand(time(0));
-
-        for (int i = 0; i != number_count; i++)
-        {
-            double sum = 0;
-            for (int j = 0; j < 12; j++)
-            {
-                sum += rand();
-            }
-            numbers[i] = sum;
-        }
+        cerr << "Enter numbers: ";
+        cin >> in.numbers[i];
     }
-    else
-    {
-        for (int i = 0; i != number_count; i++)
-        {
-            cerr << "Input number \n";
-            cin >> numbers[i];
-        }
-    }
-
-    cerr << "korzinki? ";
-    cin >> bin_count;
-    vector<double> bins(bin_count);
-
-    double min = numbers[0];
-    double max = numbers[0];
+    size_t bin_count;
+    cerr << "Enter bin count: ";
+    cin >> in.bin_count;
+    return in;
+}
 
-    for (double x : numbers)
+void
+find_minmax(const vector<double>& numbers, double& min, double& max)
+{
+    min = numbers[0];
+    for (size_t i = 1; i < numbers.size(); i++)
     {
-        if (x < min)
+        if (numbers[i] < min)
         {
-            min = x;
+            min = numbers[i];
         }
-        else if (x > max)
+        else if (numbers[i] > max)
         {
-            max = x;
+            max = numbers[i];
         }
     }
+}
+
+vector<size_t> make_histogram(const vector<double>& numbers,size_t bin_count) {
+    vector<size_t> bins(bin_count, 0);
+    double min, max;
+    find_minmax(numbers, min, max);
+
     double bin_size = (max - min) / bin_count;
-    for (size_t i = 0; i < number_count; i++)
-    {
+    if (bin_size == 0) bin_size = 1;
+
+    for (double num : numbers) {
         bool found = false;
-        for (size_t j = 0; (j < bin_count - 1) && !found; j++)
-        {
-            auto lo = min + j * bin_size;
-            auto hi = min + (j + 1) * bin_size;
-            if ((lo <= numbers[i]) && (numbers[i] < hi))
-            {
-                bins[j]++;
+        for (size_t i = 0; i < bin_count - 1; ++i) {
+            double lo = min + i * bin_size;
+            double hi = lo + bin_size;
+            if (lo <= num && num < hi) {
+                bins[i]++;
                 found = true;
+                break;
             }
         }
-        if (!found)
-        {
-            bins[bin_count - 1]++;
-        }
+        if (!found) bins.back()++;
     }
-    //---
-    //# ����� �����
-    size_t height = 76 * (static_cast<double>(bin_count) / max_count);
-
-    for (int i = 0; i != bin_count; i++)
+    return bins;
+}
+void show_histogram_text(const vector<size_t>& bins, size_t& bin_count, double bin_size)
+{
+    const size_t SCREEN_WIDTH = 80;
+    const size_t MAX_ASTERISK = SCREEN_WIDTH - 3 - 1;
+    size_t max_bin_count = bins[0];
+    for(size_t i = 0; i < bin_count; i++)
     {
-        if (bins[i] > max_count)
+        if(bins[i] > max_bin_count)
         {
-            max_count = bins[i];
+            max_bin_count = bins[i];
         }
     }
 
-    if (max_count > 76)
+    for(size_t i = 0; i < bin_count; i++)
     {
-        for (int i = 0; i != bin_count; i++)
+        if(bins[i]<10)
         {
-            if (bins[i] < 100 && bins[i] > 10)
-            {
-                cout << " " << bins[i] << "|";
-            }
-            else if (bins[i] < 10)
-            {
-                cout << "  " << bins[i] << "|";
-            }
-            else
-            {
-                cout << bins[i] << "|";
-            }
-
-            if (bins[i] != max_count)
+            cout<< "  " << bins[i] << "|";
+        }
+        else
+        {
+            if(bins[i]<100)
             {
-                height = 76 * (bins[i] / max_count);
-                for (int j = 0; j != height; j++)
-                {
-                    cout << "*";
-                }
-                cout << "\n";
+                cout<< " " << bins[i] << "|";
             }
             else
             {
-                height = 76 * 1.0;
-                for (int j = 0; j != height; j++)
+                if(bins[i]<1000)
                 {
-                    cout << "*";
+                    cout<< bins[i] << "|";
                 }
-                cout << "\n";
+
             }
         }
-    }
-    //-----
-    else
-    {
-        for (int i = 0; i != bin_count; i++)
-        {
-            if (bins[i] < 100 && bins[i] > 10)
-            {
-                cout << " " << bins[i] << "|";
-            }
-            else if (bins[i] < 10)
-            {
-                cout << "  " << bins[i] << "|";
-            }
-            else
-            {
-                cout << bins[i] << "|";
-            }
 
-            for (int j = 0; j != bins[i]; j++)
-            {
-                cout << "*";
-            }
-            cout << "\n";
+        size_t height;
+        if(max_bin_count <= MAX_ASTERISK)
+        {
+            height = bins[i];
         }
+        else
+        {
+            height = MAX_ASTERISK * (static_cast<double>(bins[i]) / max_bin_count);
+        }
+        for(size_t j = 0; j < height;  j ++)
+        {
+            cout<<"*";
+        }
+        cout<<endl;
     }
 }
+
+int main()
+{
+    auto in = input_data();
+   auto bins = make_histogram(in.numbers, in.bin_count);
+
+   double min, max;
+   double bin_size = (max - min) / in.bin_count;
+    show_histogram_text(bins, in.bin_count, bin_size);
+
+    //# ���������� + ������ ���������(�����)
+
+}
 //  | 3 3 5 5 5 4 4 4 4 4