题解 | #检测循环依赖#

检测循环依赖

http://www.nowcoder.com/practice/8dc02ad98553432a90affc3a0484910b

拓扑排序的简单运用。


class Solution {
public:
    /**
     * 代码中的类名、方法名、参数名已经指定,请勿修改,直接返回方法规定的值即可
     *
     * 
     * @param prerequisites int整型vector<vector<>> 
     * @param n int整型 
     * @return int整型vector
     */
    vector<int> findOrder(vector<vector<int> >& prerequisites, int n) {
        // write code here
        map<int,vector<int> > mp;  // a->b
        vector<int> ans;
        int indegree[2001] = {0};
        //memset(indegree,0,sizeof(indegree));
        queue<int> qu;
        for(int i = 0;i < prerequisites.size();++i){
            mp[prerequisites[i][1]].push_back(prerequisites[i][0]);
            indegree[prerequisites[i][0]]++;
        }
        for(int i = 0;i < n;++i){
            if(indegree[i] == 0)
                qu.push(i);
        }
        while(!qu.empty()){
            int start = qu.front();
            ans.push_back(start);
            qu.pop();
            for(int i = 0;i < mp[start].size();++i){
                indegree[mp[start][0]]--;
                if(indegree[mp[start][0]] == 0)
                    qu.push(mp[start][0]);
            }
        }
        if(ans.size() != n)
           ans.clear();
        return ans;
    }
};
全部评论

相关推荐

06-15 02:05
已编辑
南昌航空大学 数据分析师
Eason三木:你如果想干技术岗,那几个发公众号合唱比赛的经历就去掉,优秀团员去掉,求职没用。然后CET4这种不是奖项,是技能,放到下面的专业技能里或者单独列一个英语能力。 另外好好改改你的排版,首行缩进完全没有必要,行间距好好调调,别让字和标题背景黏在一起,你下面说能做高质量PPT你得展现出来啊,你这简历排版我用PPT做的都能比你做的好。 然后自我评价,你如果要干数据工程师,抗压能力强最起码得有吧。
简历中的项目经历要怎么写
点赞 评论 收藏
分享
评论
点赞
收藏
分享

创作者周榜

更多
牛客网
牛客网在线编程
牛客网题解
牛客企业服务