Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Vec partition could be generalized to a scatter operation #15437

Closed
pnkfelix opened this issue Jul 4, 2014 · 1 comment
Closed

Vec partition could be generalized to a scatter operation #15437

pnkfelix opened this issue Jul 4, 2014 · 1 comment

Comments

@pnkfelix
Copy link
Member

pnkfelix commented Jul 4, 2014

Current Vec offers this method:

pub fn partition(self, f: |&T| -> bool) -> (Vec<T>, Vec<T>);

That can be useful.

But sometimes you want to break up your data into more than just two groups. Maybe three; or maybe the count depends on some runtime criteria.

And also, sometimes the element itself is not the relevant predicate; sometimes the index of the element is the predicate that matters. (see e.g. #15418.)

Here's a quick sketch of a more general API:

pub fn scatter(self, num_targets: uint, g: |elem: &T, index: uint| -> uint) -> Vec<Vec<T>>;

This would work by creating N vectors, where N == num_targets, and then the function g would map each (element, index) to the vector that it should be moved to. (If g ever returns a uint >= num_targets, then the method fails.)

(Another variant of this API would not provide num_targets up front; it would instead dynamically grow the set of output vectors as necessary to accommodate the values returned by g. But I think the above API would cover a lot of cases efficiently; at worst, num_targets could be made an Option<uint> to cover both use cases.)

@pnkfelix
Copy link
Member Author

pnkfelix commented Jul 4, 2014

Well, no, the above API is silly since we already have move_iter. The use case of #15418 is trying to cover the scenario where we actually know the lengths of the vectors we are constructing ahead of time (to avoid quadratic behavior due to resize when repeatedly pushing elements to the output vectors), but that is not what I described in this ticket, since the sketched API does not provide any way for the client to say what the output lengths will/should be.

Closing (since what I proposed won't solve my problem).

@pnkfelix pnkfelix closed this as completed Jul 4, 2014
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
None yet
Projects
None yet
Development

No branches or pull requests

1 participant