溫馨提示×

C++ next_permutation如何逆序排列

c++
小樊
86
2024-07-13 04:30:23
欄目: 編程語言

要將C++的next_permutation函數(shù)應用于逆序排列的情況,可以先將數(shù)組按照逆序排序,然后在循環(huán)調(diào)用next_permutation函數(shù)。下面是一個示例代碼:

#include <iostream>
#include <algorithm>
#include <vector>

int main() {
    std::vector<int> vec = {3, 2, 1};

    // 將數(shù)組按照逆序排序
    std::sort(vec.begin(), vec.end(), std::greater<int>());

    do {
        for (int num : vec) {
            std::cout << num << " ";
        }
        std::cout << std::endl;
    } while (std::prev_permutation(vec.begin(), vec.end()));

    return 0;
}

在這個示例中,我們首先將數(shù)組{3, 2, 1}按照逆序排序得到{3, 2, 1},然后在循環(huán)中調(diào)用std::prev_permutation函數(shù)來獲取數(shù)組中所有的逆序排列組合。輸出結果為:

3 2 1 
3 1 2 
2 3 1 
2 1 3 
1 3 2 
1 2 3 

0