Родитель
dc9344efc1
Сommit
d07d11b436
@ -1,48 +1,46 @@
|
|||||||
#include "text.h"
|
#include "text.h"
|
||||||
#include <iostream>
|
#include <iostream>
|
||||||
|
|
||||||
void show_histogram(const std::vector<size_t>& bins) {
|
void show_histogram(std::vector<size_t> bins) {
|
||||||
|
|
||||||
|
|
||||||
bool gigant = false;
|
|
||||||
auto spaces = 0;
|
|
||||||
size_t mx_count = 0;
|
size_t mx_count = 0;
|
||||||
|
bool need_scale = false;
|
||||||
for (auto x : bins) {
|
for (size_t x : bins) {
|
||||||
if (x > 76) gigant = true;
|
if (x > mx_count) {
|
||||||
if (x > mx_count) mx_count = x;
|
mx_count = x;
|
||||||
|
|
||||||
auto len = 0;
|
|
||||||
auto num = x;
|
|
||||||
while (num > 0) {
|
|
||||||
num /= 10;
|
|
||||||
len++;
|
|
||||||
}
|
}
|
||||||
if (len > spaces) spaces = len;
|
if (x > 76) {
|
||||||
}
|
need_scale = true;
|
||||||
|
|
||||||
for (size_t i = 0; i < bins.size(); i++) {
|
|
||||||
|
|
||||||
int len = 1;
|
|
||||||
auto num = bins[i];
|
|
||||||
for (; num /= 10; ++len);
|
|
||||||
while (len < spaces) {
|
|
||||||
std::cout << " ";
|
|
||||||
len++;
|
|
||||||
}
|
}
|
||||||
std::cout << bins[i] << "|";
|
}
|
||||||
|
size_t max_bar = need_scale ? 76 : mx_count;
|
||||||
|
size_t digits = 1;
|
||||||
|
for (size_t t = mx_count; t >= 10; t /= 10) {
|
||||||
|
++digits;
|
||||||
|
}
|
||||||
|
|
||||||
if (gigant) {
|
for (size_t count : bins) {
|
||||||
size_t stars = (mx_count > 0) ? (76 * bins[i] / mx_count) : 0;
|
size_t bar_len = 0;
|
||||||
for (size_t j = 0; j < stars; j++) {
|
if (need_scale) {
|
||||||
std::cout << "*";
|
if (count == mx_count) {
|
||||||
|
bar_len = max_bar;
|
||||||
|
} else {
|
||||||
|
bar_len = static_cast<size_t>(max_bar * static_cast<double>(count) / mx_count);
|
||||||
}
|
}
|
||||||
} else {
|
} else {
|
||||||
for (size_t j = 0; j < bins[i]; j++) {
|
bar_len = count;
|
||||||
std::cout << "*";
|
}
|
||||||
}
|
size_t spaces = max_bar - bar_len;
|
||||||
|
for (size_t i = 0; i < spaces; ++i) {
|
||||||
|
std::cout << ' ';
|
||||||
|
}
|
||||||
|
for (size_t i = 0; i < bar_len; ++i) {
|
||||||
|
std::cout << '*';
|
||||||
|
}
|
||||||
|
std::cout << "| ";
|
||||||
|
std::string s = std::to_string(count);
|
||||||
|
for (size_t i = s.size(); i < digits; ++i) {
|
||||||
|
std::cout << ' ';
|
||||||
}
|
}
|
||||||
std::cout << std::endl;
|
std::cout << s << "\n";
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
Двоичный файл не отображается.
Двоичный файл не отображается.
Загрузка…
Ссылка в новой задаче