2026.1.25力扣刷题笔记

题目:

解答:

cpp 复制代码
class Solution {
private:
    vector<vector<int>> edges;
    vector<int> inedge;

public:
    bool canFinish(int numCourses, vector<vector<int>>& prerequisites) {
        edges.resize(numCourses);
        inedge.resize(numCourses);
        for (int i = 0; i < prerequisites.size(); i++) {
            vector<int> info = prerequisites[i]; //
            edges[info[1]].push_back(info[0]);
            inedge[info[0]]++;
        }
        queue<int> q;
        for (int i = 0; i < numCourses; i++) {
            if (inedge[i] == 0)
                q.push(i);
        }
        int visit = 0;
        while (!q.empty()) {
            visit++;
            int u = q.front();
            q.pop();
            vector<int> neig = edges[u]; //
            for (int i = 0; i < neig.size(); i++) {
                int v = neig[i];
                inedge[v]--;
                if (inedge[v] == 0)
                    q.push(v);
            }
        }
        if (visit == numCourses)
            return true;
        else
            return false;
    }
};
心得:我原本误以为只要满足前者小于后者,必然不会出现环结构,但是这是非充分必要条件,所有有例外,卡了几个例子过不去。
答案采用拓扑排序的方法,将原一维数组的有效数据分别存储为入度数和入度边,再用于拓扑排序时的出队和入队。在vector<int> neig = edges[u];直接复制给neig是一种技巧。

题目:

解答:

cpp 复制代码
class Solution {
public:
    void backrack(vector<vector<int>>& res,vector<int>& output,int first,int lens){
        if(first==lens){
            res.emplace_back(output);
            return;
        }
        for(int i=first;i<lens;i++){
            swap(output[first],output[i]);
            backrack(res,output,first+1,lens);
            swap(output[i],output[first]);
        }
    }
    vector<vector<int>> permute(vector<int>& nums) {
        vector<vector<int>> res;
        int lens=nums.size();
        backrack(res,nums,0,lens);
        return res;
    }
};
心得:这道题是回溯部分的题,用到了递归的方法,因为每次选数列中数字作为当前第一个,递归后面的排序,比如不会出现重复,得到的就是全部进行排列的结果。但因为每个都是O(n)的时间复杂度,总的为O(n!)。
相关推荐
地平线开发者12 小时前
SparseDrive 模型导出与性能优化实战
算法·自动驾驶
董董灿是个攻城狮12 小时前
大模型连载2:初步认识 tokenizer 的过程
算法
地平线开发者12 小时前
地平线 VP 接口工程实践(一):hbVPRoiResize 接口功能、使用约束与典型问题总结
算法·自动驾驶
罗西的思考13 小时前
AI Agent框架探秘:拆解 OpenHands(10)--- Runtime
人工智能·算法·机器学习
HXhlx16 小时前
CART决策树基本原理
算法·机器学习
Wect16 小时前
LeetCode 210. 课程表 II 题解:Kahn算法+DFS 双解法精讲
前端·算法·typescript
颜酱17 小时前
单调队列:滑动窗口极值问题的最优解(通用模板版)
javascript·后端·算法
Gorway1 天前
解析残差网络 (ResNet)
算法
拖拉斯旋风1 天前
LeetCode 经典算法题解析:优先队列与广度优先搜索的巧妙应用
算法
Wect1 天前
LeetCode 207. 课程表:两种解法(BFS+DFS)详细解析
前端·算法·typescript