2009-09-08 15:55:19 +02:00
|
|
|
@q $Id: fine_container.cweb 1833 2008-05-18 20:22:39Z kamenik $ @>
|
|
|
|
@q Copyright 2005, Ondra Kamenik @>
|
|
|
|
|
|
|
|
@ Start of {\tt stack\_container.cpp} file.
|
|
|
|
|
|
|
|
@c
|
|
|
|
#include "fine_container.h"
|
|
|
|
|
2009-11-03 15:16:18 +01:00
|
|
|
#include <cmath>
|
2009-09-08 15:55:19 +02:00
|
|
|
|
|
|
|
@<|SizeRefinement| constructor code@>;
|
|
|
|
|
|
|
|
@ Here we construct the vector of new sizes of containers (before
|
|
|
|
|nc|) and copy all remaining sizes behind |nc|.
|
|
|
|
|
|
|
|
@<|SizeRefinement| constructor code@>=
|
|
|
|
SizeRefinement::SizeRefinement(const IntSequence& s, int nc, int max)
|
|
|
|
{
|
|
|
|
new_nc = 0;
|
|
|
|
for (int i = 0; i < nc; i++) {
|
|
|
|
int nr = s[i]/max;
|
|
|
|
if (s[i] % max != 0)
|
|
|
|
nr++;
|
|
|
|
int ss = (nr>0) ? (int)round(((double)s[i])/nr) : 0;
|
|
|
|
for (int j = 0; j < nr - 1; j++) {
|
|
|
|
rsizes.push_back(ss);
|
|
|
|
ind_map.push_back(i);
|
|
|
|
new_nc++;
|
|
|
|
}
|
|
|
|
rsizes.push_back(s[i]-(nr-1)*ss);
|
|
|
|
ind_map.push_back(i);
|
|
|
|
new_nc++;
|
|
|
|
}
|
|
|
|
|
|
|
|
for (int i = nc; i < s.size(); i++) {
|
|
|
|
rsizes.push_back(s[i]);
|
|
|
|
ind_map.push_back(i);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
@ End of {\tt stack\_container.cpp} file.
|