【力扣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--;
            }
        }
    }
};
相关推荐
Hello:CodeWorld12 分钟前
C 风格变参 vs C++ 变参模板:核心区别与选型指南
c语言·c++·算法
8Qi81 小时前
LeetCode 516:最长回文子序列
算法·leetcode·职场和发展·动态规划
youngerwang3 小时前
【从搬运工到协处理器:网卡芯片架构、算法、验证与边缘演进深度剖析】
网络·算法·架构·芯片
KaMeidebaby3 小时前
卡梅德生物技术快报|纯化重组蛋白实操详解
人工智能·python·tcp/ip·算法·机器学习
手写码匠4 小时前
从零实现 Prompt 工程引擎:结构化提示、自动优化与多轮自省体系
人工智能·深度学习·算法·aigc
无限码力4 小时前
阿里算法岗 0530笔试真题 - 多约束条件下的元素匹配统计
算法·阿里笔试真题·阿里机试真题·阿里算法岗笔试
lqqjuly4 小时前
MLA — 多头潜在注意力深度解析
深度学习·神经网络·算法
吴可可1235 小时前
SolidWorks草图转三维DWG技巧
算法
redaijufeng5 小时前
C++雾中风景7:闭包
c++·算法·风景
小欣加油6 小时前
leetcode287寻找重复数
数据结构·c++·算法·leetcode