递增子序列,全排列

64 阅读1分钟

递增子序列

[题目](491. 递增子序列)

重点

不能进行排序,因为排序后,会出现错误的结果

代码实现

class Solution {
private:
    vector<vector<int>> result;
    vector<int> path;
    void backtracking(vector<int> & nums, int startIndex) {
        if (path.size() > 1) {
            result.push_back(path);
        }
        // 使用set对本层元素进行去重
        unordered_set<int> uset;
        for(int i = startIndex; i < nums.size(); i++) {
            if ((!path.empty() && nums[i] < path.back()) || uset.find(nums[i]) != uset.end()) {
                continue;
            }
            // 记录本层使用过的元素,本层后面不能再用了
            uset.insert(nums[i]);
            path.push_back(nums[i]);
            backtracking(nums, i + 1);
            path.pop_back();
        }
    }
public:
    vector<vector<int>> findSubsequences(vector<int>& nums) {
        backtracking(nums, 0);
    }
};

全排列

[题目](46. 全排列)

代码实现

class Solution {
private:
    vector<vector<int>> result;
    vector<int> path;
    void backtracking(vector<int> & nums, vector<bool> & used) {
        // 说明找到一组
        if (path.size() == nums.size()) {
            result.push_back(path);
            return;
        }
        for (int i = 0; i < nums.size(); i++) {
            // path里已经收集的元素,直接跳过
            if (used[i] == true) {
                continue;
            }
            path.push_back(nums[i]);
            backtracking(nums, used);
            path.pop_back();
            used[i] = false;
        }
    }
public:
    vector<vector<int>> permute(vector<int>& nums) {
        vector<bool> used(nums.size(), false);
        backtracking(nums, used);
        return result;
    }
};