【力扣hot100题】(151)课程表

最一开始的思路是和前几题一样模拟过程,但是时间复杂度很高很高。

cpp 复制代码
class Solution {
public:
    bool canFinish(int numCourses, vector<vector<int>>& prerequisites) {
        vector<bool> vec(numCourses);
        unordered_map<int,vector<int>> hash;
        for(int i=0;i<prerequisites.size();i++){
            vec[prerequisites[i][0]]=1;
            hash[prerequisites[i][0]].push_back(prerequisites[i][1]);
        }
        while(1){
            bool b=1;
            for(auto it=hash.begin();it!=hash.end();it++){
                if(vec[it->first]==0) continue;
                bool bb=0;
                vector<int> v=it->second;
                for(int i=0;i<v.size();i++) if(vec[v[i]]==1){bb=1;break;}
                if(bb==0){
                    b=0;
                    vec[it->first]=0;
                    it->second.clear();
                }
            }
            if(b==1) break;
        }
        bool b=0;
        for(int i=0;i<vec.size();i++) if(vec[i]==1) b=1;
        if(b==0) return 1;
        return 0;
    }
};

dfs时间复杂度也很高......

cpp 复制代码
class Solution {
public:
    bool result=1;
    vector<vector<int>> prerequisites;
    bool canFinish(int numCourses, vector<vector<int>>& prerequisites) {
        vector<bool> vec(numCourses);
        this->prerequisites=prerequisites;
        for(int i=0;i<vec.size();i++){
            vector<bool> v(numCourses);
            dfs(i,v);
            if(result==0) return 0;
        }
        return result;
    }
    void dfs(int now,vector<bool> v){
        v[now]=1;
        for(int i=0;i<prerequisites.size();i++){
            if(prerequisites[i][1]==now){
                if(v[prerequisites[i][0]]==1){result=0;return;}
                dfs(prerequisites[i][0],v);
                prerequisites.erase(prerequisites.begin()+i);
                i--;
            }
        }
    }
};
相关推荐
古城小栈8 小时前
为啥说:训练用BF16,推理用FP16
人工智能·算法·机器学习
KaMeidebaby8 小时前
卡梅德生物技术快报|蛋白 N 端测序在重组贻贝融合蛋白表征中的应用,解决原核表达序列偏移工艺难题
前端·人工智能·物联网·算法·百度
蓝胖的四次元口袋9 小时前
Java集合(4)
java·哈希算法
Turbo正则9 小时前
群论在AI中的应用概述
人工智能·算法·抽象代数
ysa0510309 小时前
【并查集】判环
c++·笔记·算法
Jerry9 小时前
KeetCode 44. 开发商购买土地
算法
Jerry10 小时前
KeetCode 58. 区间和
算法
Jerry10 小时前
LeetCode 209. 长度最小的子数组
算法
彦为君11 小时前
算法思维与经典智力题
java·前端·redis·算法
智能优化与强化学习11 小时前
Gym(Gymnasium)仿真环境详解(二):环境简介、入门算法、调参要点、核心挑战
算法·强化学习·gym·零基础入门·算法评估