API reference › @evolu/common › Number › computeBalancedBuckets
function computeBalancedBuckets(
numberOfItems: number & Brand<"Int"> & Brand<"NonNegative">,
numberOfBuckets?: number &
Brand<"Int"> &
Brand<"NonNegative"> &
Brand<"Positive">,
minNumberOfItemsPerBucket?: number &
Brand<"Int"> &
Brand<"NonNegative"> &
Brand<"Positive">,
): Result<
readonly [
number & Brand<"Int"> & Brand<"NonNegative"> & Brand<"Positive">,
number & Brand<"Int"> & Brand<"NonNegative"> & Brand<"Positive">,
],
number & Brand<"Int"> & Brand<"NonNegative"> & Brand<"Positive">
>;
Defined in: packages/common/src/Number.ts:71
Divides items into buckets as evenly as possible, ensuring each bucket has at least the minimum number of items. Returns a success result if the minimum is met, or an error result with the required number of items if not.
Example
computeBalancedBuckets(10, 3, 2); // Returns ok([4, 7, 10])
computeBalancedBuckets(5, 3, 2); // Returns err(6)