Sign Up

Sign Up to our social questions and Answers Engine to ask questions, answer people’s questions, and connect with other people.

Have an account? Sign In

Have an account? Sign In Now

Sign In

Login to our social questions & Answers Engine to ask questions answer people’s questions & connect with other people.

Sign Up Here

Forgot Password?

Don't have account, Sign Up Here

Forgot Password

Lost your password? Please enter your email address. You will receive a link and will create a new password via email.

Have an account? Sign In Now

You must login to ask a question.

Forgot Password?

Need An Account, Sign Up Here

Please briefly explain why you feel this question should be reported.

Please briefly explain why you feel this answer should be reported.

Please briefly explain why you feel this user should be reported.

Sign InSign Up

The Archive Base

The Archive Base Logo The Archive Base Logo

The Archive Base Navigation

  • SEARCH
  • Home
  • About Us
  • Blog
  • Contact Us
Search
Ask A Question

Mobile menu

Close
Ask a Question
  • Home
  • Add group
  • Groups page
  • Feed
  • User Profile
  • Communities
  • Questions
    • New Questions
    • Trending Questions
    • Must read Questions
    • Hot Questions
  • Polls
  • Tags
  • Badges
  • Buy Points
  • Users
  • Help
  • Buy Theme
  • SEARCH
Home/ Questions/Q 6154689
In Process

The Archive Base Latest Questions

Editorial Team
  • 0
Editorial Team
Asked: May 23, 20262026-05-23T20:18:15+00:00 2026-05-23T20:18:15+00:00

Is it more efficient to begin with a possibly random ordering of objects in

  • 0

Is it more efficient to begin with a possibly random ordering of objects in a range, using next_permutation to step through all greater permutations, followed by stepping down, beginning again with the original ordering, using prev_permutation to reach the last.

Or, to sort the range before permuting, then to use only next_permutation to step through all of them?

  • 1 1 Answer
  • 0 Views
  • 0 Followers
  • 0
Share
  • Facebook
  • Report

Leave an answer
Cancel reply

You must login to add an answer.

Forgot Password?

Need An Account, Sign Up Here

1 Answer

  • Voted
  • Oldest
  • Recent
  • Random
  1. Editorial Team
    Editorial Team
    2026-05-23T20:18:16+00:00Added an answer on May 23, 2026 at 8:18 pm

    next_permutation will step through all permutations, not only through greater permutations. No need to revert and use prev_permutation, and certainly no need to sort.

    You only need take care of the fact that next_permutation will return false once it “rolls over” into the lexicographically lowest permutation so you need to keep track of the number of the current permutation to know when to stop.

    That is, the following will iterate through all possible permutations of a range, no matter how the starting range looks like.

    size_t const num_permutations = multinomial_coefficient(range);
    
    for (size_t i = 0; i < num_permutations; ++i) {
        next_permutation(range.begin(), range.end());
        // use permutation.
    }
    

    Where multinomial_coefficient is the multinomial coefficient of the number of distinct elements in the range. In the simple case where all elements are distinct, this is equivalent to N!, the factorial of the number of elements.

    • 0
    • Reply
    • Share
      Share
      • Share on Facebook
      • Share on Twitter
      • Share on LinkedIn
      • Share on WhatsApp
      • Report

Sidebar

Related Questions

Is there a more efficient way to clamp real numbers than using if statements
I've found out the following article about A More Efficient Method for Paging Through
Which is more efficient for the compiler and the best practice for checking whether
Is there a more efficient way to convert an HTMLCollection to an Array, other
Is it more efficient for a class to access member variables or local variables?
Which is more efficient? SELECT theField FROM theTable GROUP BY theField or SELECT DISTINCT
What is more efficient -- having a IDbTransaction in the .net code or handling
Is there are more efficient way than the following for selecting the third parent?
Is it better (more efficient, faster, more secure, etc) to (A) cache data that
The DataReader is more efficient than a DataTable if you only need to show

Explore

  • Home
  • Add group
  • Groups page
  • Communities
  • Questions
    • New Questions
    • Trending Questions
    • Must read Questions
    • Hot Questions
  • Polls
  • Tags
  • Badges
  • Users
  • Help
  • SEARCH

Footer

© 2021 The Archive Base. All Rights Reserved
With Love by The Archive Base

Insert/edit link

Enter the destination URL

Or link to existing content

    No search term specified. Showing recent items. Search or use up and down arrow keys to select an item.