社区讨论
AI写的,思路我觉得挺新奇,但是WA,各位大佬帮忙看看呗(不喜勿喷)
P1706全排列问题参与者 2已保存回复 3
讨论操作
快速查看讨论及其快照的属性,并进行相关操作。
- 当前回复
- 3 条
- 当前快照
- 1 份
- 快照标识符
- @mdedfjjl
- 此快照首次捕获于
- 2025/07/22 18:07 7 个月前
- 此快照最后确认于
- 2025/11/04 03:55 4 个月前
CPP
#include <iostream>
#include <vector>
#include <iomanip> // 用于 std::setw
using namespace std;
void permute(vector<int>& nums, vector<bool>& used, vector<int>& current, vector<vector<int>>& result) {
if (current.size() == nums.size()) {
result.push_back(current);
return;
}
for (int i = 0; i < nums.size(); i++) {
if (!used[i]) {
used[i] = true;
current.push_back(nums[i]);
permute(nums, used, current, result);
current.pop_back();
used[i] = false;
}
}
}
int main() {
int n;
cin >> n;
vector<int> nums(n);
for (int i = 0; i < n; i++) {
nums[i] = i + 1;
}
vector<bool> used(n, false);
vector<int> current;
vector<vector<int>> result;
permute(nums, used, current, result);
for (const auto& perm : result) {
for (int num : perm) {
cout << setw(6) << num;
}
cout << endl;
}
return 0;
}
回复
共 3 条回复,欢迎继续交流。
正在加载回复...