算法/C++ STL排列&手动可选择排列

cpp 复制代码
#include<bits/stdc++.h>
using namespace std;
int main()
{
    string s;
    cin >> s;
    sort(s.begin(), s.end());
    do {
        cout << s << endl;
    } while (next_permutation(s.begin(), s.end()));
    cout << endl;
    sort(s.begin(), s.end(),greater<char>());
    do {
        cout << s << endl;
    } while (prev_permutation(s.begin(), s.end()));
    return 0;
}

简单明了,全靠 next/prev_permutation 函数,这是一个非常好用的排序函数,但无法进行剪枝的操作,即在明知当前排列已经错误时无法停止,会导致超时。

这是就需要我们手写一个排列函数

cpp 复制代码
#include<bits/stdc++.h>
using namespace std;

vector<int> a={1,2,3,4,5,6,7,8,9,10};
bool vis[20];
int b[20];

void dfs(int s,int t,vector<int>&a2){
    if(s == t){
        for(int i = 0; i < t; ++i) cout << b[i] << " ";
        cout << endl;
        return;
    }
//剪枝操作
    for(int i = 0; i < t; i++){
        if(!vis[i]){
            vis[i] = true;
            b[s] = a2[i];
            dfs(s + 1,t,a2);
            vis[i] = false;
        }
    }
    return;
}
int main(){
    int start,end;
    cin>>start>>end;
     vector<int> a2(a.begin() + start - 1, a.begin() + end);
    dfs(0,end-start+1,a2);
    return 0;
}

这里没有具体的例子大致是满足一个具体的条件后return结束递归

相关推荐
TomCode先生28 分钟前
c#动态树形表达式详解
开发语言·c#
高-老师1 小时前
基于R语言的物种气候生态位动态量化与分布特征模拟
开发语言·r语言·物种气候
大翻哥哥1 小时前
Python 2025:量化金融与智能交易的新纪元
开发语言·python·金融
~|Bernard|1 小时前
在 PyCharm 里怎么“点鼠标”完成指令同样的运行操作
算法·conda
战术摸鱼大师1 小时前
电机控制(四)-级联PID控制器与参数整定(MATLAB&Simulink)
算法·matlab·运动控制·电机控制
Christo32 小时前
TFS-2018《On the convergence of the sparse possibilistic c-means algorithm》
人工智能·算法·机器学习·数据挖掘
weixin_437830942 小时前
使用冰狐智能辅助实现图形列表自动点击:OCR与HID技术详解
开发语言·javascript·ocr
鹿鹿学长2 小时前
2025年全国大学生数学建模竞赛(C题) 建模解析|婴儿染色体数学建模|小鹿学长带队指引全代码文章与思路
c语言·开发语言·数学建模
好家伙VCC3 小时前
数学建模模型 全网最全 数学建模常见算法汇总 含代码分析讲解
大数据·嵌入式硬件·算法·数学建模
zhousenshan3 小时前
Python爬虫常用框架
开发语言·爬虫·python