c++全排列的递归算法怎么实现

c++
1418
2023/9/14 11:06:57
栏目: 编程语言
开发者测试专用服务器限时活动,0元免费领,库存有限,领完即止! 点击查看>>

下面是C++中全排列的递归算法的实现:

#include <iostream>
#include <vector>
using namespace std;
// 交换两个元素的位置
void swap(vector<int>& nums, int i, int j) {
int temp = nums[i];
nums[i] = nums[j];
nums[j] = temp;
}
// 递归生成全排列
void permuteHelper(vector<int>& nums, int begin, vector<vector<int>>& result) {
if (begin == nums.size()) {
result.push_back(nums);
return;
}
for (int i = begin; i < nums.size(); i++) {
swap(nums, begin, i);
permuteHelper(nums, begin + 1, result);
swap(nums, begin, i);  // 恢复原来的位置,以便进行下一次交换
}
}
vector<vector<int>> permute(vector<int>& nums) {
vector<vector<int>> result;
permuteHelper(nums, 0, result);
return result;
}
int main() {
vector<int> nums = {1, 2, 3};
vector<vector<int>> result = permute(nums);
for (vector<int>& permutation : result) {
for (int num : permutation) {
cout << num << " ";
}
cout << endl;
}
return 0;
}

该算法通过递归实现全排列。首先,定义一个permuteHelper函数,该函数用于生成从指定位置开始的全排列。在遍历过程中,将当前位置的元素与后面的元素逐个交换,并继续递归生成全排列。当遍历到最后一个位置时,将当前排列添加到结果中。

在主函数中,定义一个测试用例nums,然后调用permute函数生成全排列,并打印结果。

辰迅云「云服务器」,即开即用、新一代英特尔至强铂金CPU、三副本存储NVMe SSD云盘,价格低至29元/月。点击查看>>

推荐阅读: c++位运算符的运算规则是什么