社区讨论

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 条回复,欢迎继续交流。

正在加载回复...