c++ next_permutation 枚举排列数

19 篇文章 0 订阅
10 篇文章 0 订阅
  1. 这个函数会改变原数组本身。
  2. 每执行一次就会返回当前字典序的下一个升序字典序。
  3. 所以如果想遍历所有排列的话数组需要初始化为最小字典序。

测试程序:

    int num[10] = {1, 3, 2, 5, 4};

    while(next_permutation(num, num+5)){
        cout << "!!!!!" << endl;
        for(int i = 0; i < 5; i++)
            cout << num[i];
        cout << endl;
    }
    for(int i = 0; i < 5; i++)
        cout << num[i];
    cout << endl;
C++的next_permutation是一个STL函,用于求一个序列的下一个字典序排列。它包含在头文件<algorithm>中。使用next_permutation可以方便地生成一个序列的所有可能排列。您可以通过传入一个组和组的大小来使用next_permutationC++的STL库提供了next_permutation,它可以自动计算下一个排列,无需手动实现。要使用next_permutation,您需要包含<algorithm>头文件,并使用该函进行迭代处理,直到没有下一个排列为止。手动实现next_permutation的方法是,首先找到一个逆序的位置,然后找到一个比该位置上元素大的元素,并将这两个元素交换位置,最后将逆序位置后面的元素颠倒顺序。这样就得到了下一个排列。通过不断重复这个过程,直到没有下一个排列为止。手动实现next_permutation的代码如下:<span class="em">1</span><span class="em">2</span><span class="em">3</span> #### 引用[.reference_title] - *1* *2* [C++中 next_permutation的使用方法、原理及手动实现](https://blog.csdn.net/m0_51913750/article/details/130540032)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v93^chatsearchT3_2"}}] [.reference_item style="max-width: 50%"] - *3* [详谈全排列next_permutation() 函的用法(推荐)](https://download.csdn.net/download/weixin_38651365/13784181)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v93^chatsearchT3_2"}}] [.reference_item style="max-width: 50%"] [ .reference_list ]
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值