【力扣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--;
            }
        }
    }
};
相关推荐
KAU的云实验台7 分钟前
单/多UAV、静/动态路径规划,基于PlatEMO平台的带约束多目标优化 本文核心内容:
算法·matlab·无人机
Liangwei Lin11 分钟前
洛谷 P1807 最长路
数据结构·算法
会编程的土豆25 分钟前
【数据结构与算法】二叉树从建立开始
数据结构·c++·算法
_日拱一卒26 分钟前
LeetCode:最大子数组和
数据结构·算法·leetcode
计算机安禾1 小时前
【数据结构与算法】第22篇:线索二叉树(Threaded Binary Tree)
c语言·开发语言·数据结构·学习·算法·链表·visual studio code
算法鑫探1 小时前
解密2025数字密码:数位统计之谜
c语言·数据结构·算法·新人首发
计算机安禾1 小时前
【数据结构与算法】第21篇:二叉树遍历的经典问题:由遍历序列重构二叉树
c语言·数据结构·学习·算法·重构·visual studio code·visual studio
信奥胡老师1 小时前
P1255 数楼梯
开发语言·数据结构·c++·学习·算法
爱睡懒觉的焦糖玛奇朵2 小时前
【工业级落地算法之人员摔倒检测算法详解】
人工智能·python·深度学习·神经网络·算法·yolo·目标检测
小辉同志2 小时前
78. 子集
算法·leetcode·深度优先