#include #include using namespace std; const int max_length = 80; // максимальная длина const int indent = 4; // отступ int main() { size_t number_count, bin_count; cerr << "Enter number count: "; cin >> number_count; // ввод кол-ва оценок vector numbers(number_count); cerr << "Enter numbers: " << endl; for (int i = 0; i < number_count; i++) { cin >> numbers[i]; // ввод оценок } cerr << "Enter bin count: "; cin >> bin_count; // ввод кол-ва корзин vector bins(bin_count); for (int i = 0; i < bin_count; i++) { bins[i] = 0; } double min = 5; double max = 0; for (int i = 0; i < number_count; i++) { // определение макс и мин оценок if (numbers[i] > max) { max = numbers[i]; } if (numbers[i] < min) { min = numbers[i]; } } double bin_size = (max - min) / bin_count; // определение размера корзины и шага double step = bin_size; for (int i = 0; i < number_count; i++) { bool found = false; // условие вхождения в какой-либо промежуток, кроме последнего for (int 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]++; } } double max_bin = bins[0]; int k; for (int i = 0; i < bin_count; i++) { // нахождение макс значения bin[] if (bins[i] > max_bin) { max_bin = bins[i]; } } if (max_bin <= (max_length - indent)) { // сравнение длины строки "*" с максимальной длиной выводимой строки k = 0; } else { k = 1; } cerr << endl; int out; for (int i = 0; i < bin_count; i++) { cout.width(3); // выравнивание cout.fill(' '); cout << bins[i] << "|"; if (k == 0) { // масштабирование out = bins[i]; // обычный вывод } else { out = bins[i] * (max_length - indent) / max_bin; // масштабированный вывод } for (int j = 0; j < out; j++) { cout << "*"; } cout << endl; } return 0; }