Родитель
736a9d128b
Сommit
2de2bac5f4
@ -0,0 +1,53 @@
|
|||||||
|
#include "histogram.h"
|
||||||
|
#include <vector>
|
||||||
|
#include "histogram_internal.h"
|
||||||
|
|
||||||
|
using namespace std;
|
||||||
|
void find_minmax(const vector<double>& numbers, double& minp, double& maxp)
|
||||||
|
{
|
||||||
|
minp = numbers[0];
|
||||||
|
for (auto i = 0; i<numbers.size(); i++)
|
||||||
|
{
|
||||||
|
if (numbers[i]<minp)
|
||||||
|
{
|
||||||
|
minp = numbers[i];
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
maxp = numbers[0];
|
||||||
|
for (auto i = 0; i<numbers.size(); i++)
|
||||||
|
{
|
||||||
|
if (numbers[i]>maxp)
|
||||||
|
{
|
||||||
|
maxp = numbers[i];
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
vector <size_t> make_histogram (const vector<double>& numbers, size_t kol_kor)
|
||||||
|
{
|
||||||
|
vector<size_t>B(kol_kor);
|
||||||
|
size_t max_count;
|
||||||
|
double maxp, minp;
|
||||||
|
find_minmax(numbers, minp, maxp);
|
||||||
|
double step = (maxp-minp)/(kol_kor);
|
||||||
|
|
||||||
|
for (size_t i=0; i<numbers.size(); i++)
|
||||||
|
{
|
||||||
|
for (size_t j=0; j<kol_kor; j++)
|
||||||
|
{
|
||||||
|
if ((numbers[i]>=(minp+j*step))&&(numbers[i]<(minp+(j+1)*step)))
|
||||||
|
{
|
||||||
|
B[j]++;
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
for (size_t i=0; i<numbers.size(); i++)
|
||||||
|
{
|
||||||
|
if (numbers[i]== maxp)
|
||||||
|
B[kol_kor-1]++;
|
||||||
|
}
|
||||||
|
return B;
|
||||||
|
}
|
Загрузка…
Ссылка в новой задаче