Alice (KharisovSR) 2 лет назад
Родитель 9f192136c6
Сommit d83432d1e6

@ -3,28 +3,39 @@
using namespace std; using namespace std;
int main() struct Input
{ {
size_t number_count;//êîëè÷åñòâî ÷èñåë vector<double> numbers;
cerr<<"vvod chisel"; size_t bin_count{};
cin>>number_count; };
vector <double> numbers(number_count);//âåêòîð ñ êîëè÷ñåòâîì ýëåìåíòîâ number_count Input
input_data()
{
Input in;
size_t number_count;
cin>>number_count;
in.numbers.resize(number_count);
cout<<endl;//çàïîëíåíèå âåêòîðà vector <double> numbers(number_count);
cout<<endl;
for(size_t i=0; i<number_count; i++) for(size_t i=0; i<number_count; i++)
{ {
cin>>numbers[i]; cin>>in.numbers[i];
} }
size_t bin_count;//êîëè÷åñòâî êîðçèí size_t bin_count;
cin>>bin_count; cin>>in.bin_count;
vector<size_t> bins(bin_count); vector<size_t> bins(bin_count);
return in;
}
double min = numbers[0];//ïîèñê ìèí void find_minmax(const vector<double>& numbers, double& min, double& max)
double max = numbers[0];//ïîèñê ìàêñ {
for (double x : numbers)//öèêë äíÿ âñåõ åëåìåíòîâ numbers min = numbers[0];
max = numbers[0];
for (double x : numbers)
{ {
if (x < min) if (x < min)
{ {
@ -36,85 +47,12 @@ int main()
} }
} }
}
double bin_size = (max-min)/bin_count;//ðàçìåð êîðçèíû int main()
{
for (size_t i = 0; i < number_count; i++)//çàïîëíåíèå Input in = input_data();
{ double min, max;
bool found = false; vector<double> numbers;
for (size_t j = 0; (j < bin_count - 1) && !found; j++) find_minmax( numbers, min, max);
{
auto lo = min + j * bin_size;
auto 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 i =0; i<bin_count; i++)
{
if (max_count <bins[i])
{
max_count=bins[i];
}
}
int proc;
int sum =0;
for(size_t i=0; i<bin_count; i++)//âûâîä ñ ïðîöåíòàìè
{
if (i==bin_count-1)
{
proc=100-sum;
}
else
{
proc =((float)bins[i] / number_count)*100;
}
sum+=proc;
if (proc<10)//âûðàâíèâàíèå ñ %
{
cout<<" "<<proc<<"% | ";
}
if ((proc<100)&&(proc>=10))
{
cout<<" "<<proc<<"% | ";
}
size_t height = 0;
if (max_count>75)//ìàøòàáèðîâàíèå
{
size_t height = 75 * (static_cast<double>(bins[i]) / max_count);
for(size_t j=0; j<=height; j++)
{
cout<<"*";
}
}
else
{
for(size_t j=0; j<=bins[i]-1; j++)
{
cout<<"*";
}
}
cout<<endl;
}
} }

Загрузка…
Отмена
Сохранить