commit 4475c84c98e0b427b0c955c2e778fadd9fa1ea48 Author: ShevchukDS Date: Sat May 31 00:16:11 2025 +0300 Добавлены исходный код и проект diff --git a/lab01.cbp b/lab01.cbp new file mode 100644 index 0000000..d541ad7 --- /dev/null +++ b/lab01.cbp @@ -0,0 +1,40 @@ + + + + + + diff --git a/main.cpp b/main.cpp new file mode 100644 index 0000000..e4afdd3 --- /dev/null +++ b/main.cpp @@ -0,0 +1,100 @@ +#include +#include + + +using namespace std; + +int main() +{ + const size_t SCREEN_WIDTH = 80; + const size_t MAX_ASTERISK = SCREEN_WIDTH - 3 - 1; + + char a,b,c; + cout << "viravnit = "; + cin >> a; + cout << "osi = "; + cin >> b; + cout << "risunok = "; + cin >> c; + + cout << "viravnit = " << a << '\n' + << "osi = " << b << '\n' + << "risunok = " << c << '\n'; + if (a == '\t' || a == '\n' || b == '\t' || b == '\n' || c == '\t' || c == '\n') { + cout << "ERROR!"; + return 0; + } + + int number_count, bucket; + + do + { + cerr << "Enter number count: "; cin >> number_count; + } + while (number_count < 1); + + do + { + cerr << "Enter bucket: "; cin >> bucket; + } + while (bucket < 1); + + cerr << "\n"; + + vector numbers(number_count); + for (int i = 0; i < number_count; i++) cin >> numbers[i]; + + float min = numbers[0]; + float max = numbers[0]; + + for (float x : numbers) + { + if (x < min) min = x; + else if (x > max) max = x; + } + + float k = (max-min)/bucket; + + vector stolb(bucket); + + for (int j = 0; j < bucket; j++) stolb[j] = 0; + + for (int i = 0; i < number_count; i++) + { + bool flag = false; + for (int j = 0; (j < bucket && !flag); j++) + { + if (numbers[i] >= (min+k*j) && numbers[i] < (min+k*(1+j))) + { + stolb[j]++; + flag = true; + + } + } + if (!flag) stolb[bucket-1]++; + } + + int maxlen = 0; + + for (int j = 0; j < bucket; j++) + { + if (maxlen MAX_ASTERISK) + { + if (maxlen != stolb[j]) height = MAX_ASTERISK * (static_cast(stolb[j])/maxlen); + else if (maxlen == stolb[j]) height = MAX_ASTERISK; + } + for (int i = 0; i < height; i++) cout << c; + cout << "\n"; + } + + return 0; +}