The std::next_permutation and std::prev_permutation algorithms reorder elements of a range into the next/previous lexicographical permutation.
If no such permutation exists, both algorithms roll over and return false.
Compiler Explorer link: https://compiler-explorer.com/z/69sfEexaE