牛客NC218 检测循环依赖【中等 图 Java,Go,PHP】

题目

在这里插入图片描述
题目链接:
https://www.nowcoder.com/practice/8dc02ad98553432a90affc3a0484910b

思路

图的基本知识要理解,一般用Map来表示
图解决拓扑排序,依赖之类的问题
感觉课程数在这道题里面可以不用,因为没有规定所有课程都得有先修,
所有先修约束里面可能就     没有包含所有课程

参考答案Java

import java.util.*;


public class Solution {
    /**
     * 代码中的类名、方法名、参数名已经指定,请勿修改,直接返回方法规定的值即可
     *
     *
     * @param prerequisites int整型二维数组
     * @param n int整型
     * @return int整型一维数组
     */
    public int[] findOrder (int[][] prerequisites, int n) {
        //map表示图
        Map<Integer, Node> g = new HashMap<>();
        for (int[] item : prerequisites) {
            int fv = item[1];
            int tv = item[0];

            if (!g.containsKey(fv))
                g.put(fv, new Node(fv));

            if (!g.containsKey(tv))
                g.put(tv, new Node(tv));

            Node fn = g.get(fv);
            Node tn = g.get(tv);
            fn.nexts.add(tn);
            tn.in++;
        }

        Queue<Node> q0 = new LinkedList<>();
        for (Node cur : g.values()) {
            if (cur.in == 0) {
                q0.add(cur);
            }
        }

        List<Integer> list = new ArrayList<>();
        int cnt = 0;
        while (!q0.isEmpty()) {
            int size = q0.size();
            for (int i = 0; i < size ; i++) {
                Node poll = q0.poll();
                cnt++;

                if (list.contains(poll.data)) return new int[0];

                list.add(poll.data);

                for (Node next : poll.nexts) {
                    if (--next.in == 0) {
                        q0.add(next);
                    }
                }
            }
        }

        int[] ans = new int[list.size()];
        for (int i = 0; i < list.size() ; i++) {
            ans[i] = list.get(i);
        }
        return ans;
    }

    static class Node {
        int data;
        int in = 0;
        List<Node> nexts = new ArrayList<>();
        public Node(int d) {
            data = d;
        }
    }
}

参考答案Go

package main



/**
 * 代码中的类名、方法名、参数名已经指定,请勿修改,直接返回方法规定的值即可
 *
 *
 * @param prerequisites int整型二维数组
 * @param n int整型
 * @return int整型一维数组
 */
func findOrder(prerequisites [][]int, n int) []int {
	//map 模拟图
	g := map[int]*GNode{}
	for _, v := range prerequisites {
		fv := v[1]
		tv := v[0]

		_, okf := g[fv]
		if !okf {
			g[fv] = CreateGnode(fv)
		}
		_, okt := g[tv]
		if !okt {
			g[tv] = CreateGnode(tv)
		}

		fn := g[fv]
		tn := g[tv]

		fn.nexts = append(fn.nexts, tn)
		tn.in++
	}

	//Go中用切片模拟Java中的队列Queue
	q0 := []*GNode{} //每次进入队列的都是入度为0的
	for _, cur := range g {
		if cur.in == 0 {
			q0 = append(q0, cur)
		}
	}

	set := map[int]bool{}
	ans := []int{}

	for len(q0) > 0 {
		size := len(q0)
		q0bak := []*GNode{}
		for i := 0; i < size; i++ {
			poll := q0[i]

			_, exist := set[poll.data]
			if exist {
				return []int{}
			}

			set[poll.data] = true
			ans = append(ans, poll.data)

			for _, next := range poll.nexts {
				next.in--
				if next.in == 0 {
					q0bak = append(q0bak, next)
				}
			}
		}

		q0 = q0bak
	}
	return ans
}

type GNode struct { //图节点的定义
	data  int
	in    int      //入度
	nexts []*GNode // 图的邻居有哪些
}

func CreateGnode(d int) *GNode { //新建节点
	return &GNode{d, 0, []*GNode{}}
}

参考答案PHP

<?php


/**
 * 代码中的类名、方法名、参数名已经指定,请勿修改,直接返回方法规定的值即可
 *
 * 
 * @param prerequisites int整型二维数组 
 * @param n int整型 
 * @return int整型一维数组
 */
function findOrder( $prerequisites ,  $n )
{
    //图
    $map =array();
    foreach ($prerequisites as $v){
        $fv = $v[1];
        $tv = $v[0];

        if(!isset($map[$fv]))
            $map[$fv] = new Node($fv);
        if(!isset($map[$tv]))
            $map[$tv] = new Node($tv);

        $fv = $map[$fv];
        $tn = $map[$tv];
        array_push($fv->nexts,$tn);
        $tn->in++;
    }

    //队列,PHP中的数组也是队列
    $q0 = array();
    foreach ($map as $cur){
        if($cur->in ==0)
            array_push($q0,$cur);
    }

    $ans = array();

    while (count($q0) >0){
        $size = count($q0);
        for($i=0;$i<$size;$i++){
            $poll = array_shift($q0);

            if(in_array($poll->data,$ans)) return array();

            array_push($ans,$poll->data);

            foreach ($poll->nexts as $next){
                $next->in--;
                if($next->in ==0){
                    array_push($q0,$next);
                }
            }
        }
    }

    return $ans;
}

class Node{ //图
    public $data;
    public $in;
    public $nexts;
    public function Node($d){
        $this->data = $d;
        $this->in =0;
        $this->nexts =array();
 }
}

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:/a/485295.html

如若内容造成侵权/违法违规/事实不符,请联系我们进行投诉反馈qq邮箱809451989@qq.com,一经查实,立即删除!

相关文章

解决方案Please use Oracle(R) Java(TM) 11, OpenJDK(TM) 11 to run Neo4j.

文章目录 一、现象二、解决方案 一、现象 当安装好JDK跟neo4j&#xff0c;用neo4j.bat console来启动neo4却报错&#xff1a; 部分报错信息&#xff1a; Starting Neo4j. WARNING! You are using an unsupported Java runtime. Please use Oracle Java™ 11, OpenJDK™ 11 t…

Jenkins中使用Generic Webhook Trigger插件实现持续集成

项目环境 宝塔Linux面板DockerJenkinsgitee 目的 实现每次push推送dev分支到gitee上&#xff0c;Jenkins自动构建项目&#xff1b;push其它分支时&#xff0c;不运行。 实现方法 1.在Jenkins上安装Generic Webhook Trigger插件 在“系统设置–插件管理–可选插件”界面搜…

jmeter中参数加密

加密接口常用的方式有&#xff1a; MD5&#xff0c;SHA&#xff0c;HmacSHA RSA AES&#xff0c;DES&#xff0c;Base64 压测中有些参数需要进行加密&#xff0c;加密方式已接口文档为主。 MD5加密 比如MD5加密的接口文档&#xff1a; 请求URL&#xff1a;http://101.34.221…

STM32 | Systick定时器(第四天源码解析)

STM32 | Systick定时器(第四天)STM32 | STM32F407ZE中断、按键、灯(续第三天)1、参考delay_us代码,完成delay_ms的程序 定时器频率换算单位:1GHZ=1000MHZ=1000 000KHZ = 1000 000 000HZ 定时器定时时间:计数个数/f(频率) 或者 (1/f(频率))*计数的个数 500/1MHZ = 500/1…

Spring相关框架八股

单例bean是线程安全的吗&#xff1f; AOP 事务失效 Bean生命周期 Bean循环依赖解决 MVC执行流程 自动装配原理 Spring常见注解 SpringMVC注解 SpringBoot注解 MyBatis执行流程 MyBatis延迟加载 MyBatis缓存 SpringCloud五大组件 注册中心Nacos、Eureka 负载均衡Ribbon 服务雪崩…

Godot.NET C# 工程化开发(1):通用Nuget 导入+ 模板文件导出,包含随机数生成,日志管理,数据库连接等功能

文章目录 前言Github项目地址&#xff0c;包含模板文件后期思考补充项目设置编写失误环境visual studio 配置详细的配置看我这篇文章 Nuget 推荐NewtonSoft 成功Bogus 成功Github文档地址随机生成构造器生成构造器接口(推荐) 文件夹设置Nlog 成功&#xff01;Nlog.configNlogHe…

2025汤家凤考研数学视频,基础网课百度网盘课程+PDF讲义资料

2025汤家凤大神及数学全程 docs.qq.com/doc/DTmtOa0Fzc0V3WElI 复制粘贴到浏览器&#xff0c;可以见所有的Ke 第一轮 夯实基础 1.阅读大纲考查要求&#xff0c;明确每章的学习目标&#xff1b; 2.按节学习数学理论基础知识&#xff0c;吃透书中例题&#xff1b; 3.学习每章…

红外遥控器的使用和详细解释

infrared.c #include "infrared.h"/* 红外 --- PA8*/void Infrared_Init(void) {GPIO_InitTypeDef GPIO_InitStruct; EXTI_InitTypeDef EXTI_InitStruct;NVIC_InitTypeDef NVIC_InitStruct;//使能SYSCFG时钟RCC_APB2PeriphClockCmd(RCC_APB2Periph_SYSCFG, E…

【数据结构】五分钟自测主干知识(十)

上一节&#xff0c;我们讲述了二叉树的概念&#xff0c;二叉树又有什么基本操作呢&#xff1f;今天我们来讲述二叉树的应用~ 话不多说&#xff0c;书继上回 5.3二叉树的遍历及应用 二叉树由三个基本部分组成&#xff1a;根结点&#xff08;D&#xff09;&#xff0c;左子树&a…

ForkJoinPool在生产环境中使用遇到的一个问题

1、背景 在我们的项目中有这么一个场景&#xff0c;需要消费kafka中的消息&#xff0c;并生成对应的工单数据。早些时候程序运行的好好的&#xff0c;但是有一天&#xff0c;我们升级了容器的配置&#xff0c;结果导致部分消息无法消费。而消费者的代码是使用CompletableFutur…

综合知识篇21-项目管理考点(2024年软考高级系统架构设计师冲刺知识点总结系列文章)

专栏系列文章: 2024高级系统架构设计师备考资料(高频考点&真题&经验)https://blog.csdn.net/seeker1994/category_12593400.html案例分析篇00-【历年案例分析真题考点汇总】与【专栏文章案例分析高频考点目录】(2024年软考高级系统架构设计师冲刺知识点总结-案例…

数据结构:插入排序,希尔排序(缩小增量排序)

1.直接插入排序 当插入第 i 个元素时,前面的数据已经排好序了,将后续的数据按大小插入到前面已经排好序的数组中,就是插入排序 特点 1.元素集合越接近有序,时间效率越高 2.时间复杂度O(N^2) 3.空间复杂度O(1) //插入排序 void InsertSort(int* a, int length) {for (int …

2021年XX省赛职业院校技能大赛”高职组 计算机网络应用赛项 网络构建模块竞赛真题

“2021年XX省赛职业院校技能大赛”高职组 计算机网络应用赛项 网络构建模块竞赛真题 目录 一&#xff0e;考试说明 1 二&#xff0e;模块B网络构建 2 &#xff08;一&#xff09;任务描述 2 &#xff08;二&#xff09;任务清单 9 一&#xff0e;考试说明 本模块比赛时间为…

腾讯云服务器价格查询系统,2024年1年、3年和5年活动价格表

腾讯云服务器多少钱一年&#xff1f;61元一年起。2024年最新腾讯云服务器优惠价格表&#xff0c;腾讯云轻量2核2G3M服务器61元一年、2核2G4M服务器99元一年可买三年、2核4G5M服务器165元一年、3年756元、轻量4核8M12M服务器646元15个月、4核16G10M配置32元1个月、312元一年、8核…

windows11 openssh服务开启;第三方ping不通局域网windows电脑;ssh连接内部ubuntu系统

参考&#xff1a;https://blog.csdn.net/2301_77554343/article/details/134328867 1、windows11 openssh开启 1&#xff09;我这边可选功能在设置-系统里面&#xff1b;其他网上看在应用下&#xff1b;添加可选openssh服务器安装 2&#xff09;安装后打开&#xff0c;管理员…

vscode的一些技巧

技巧1&#xff1a;调试时传参数 在launch.json的configuration中"pwd"或者"program"选项之后添加如下选项&#xff1a; “--args”:["参数1", "参数2", ..., "参数3] 参数之间使用逗号隔开 技巧2&#xff1a;断点 普通断点使…

数据结构:选择排序,快速排序

1.选择排序 直接遍历数组,找出最大值和最小值,记录下标,将最大值和最小值分别与首位交换 但是由于当begin maxi时,会导致出错,因此需要 if 特殊判断 void Swap(int* a, int* b) {int temp *a;*a *b;*b temp; }void SelectSort(int* a, int n) {int begin 0;int end n …

谷歌地球三维模型下载软件更新

收费软件&#xff0c;白嫖党勿扰 收费金额2000元 1 概述 之前写过一篇《谷歌模型下载》的文章&#xff0c;反馈特别好。我也很欣慰&#xff0c;能够帮到一些同学。但是&#xff0c;有同学反应&#xff0c;软件确实帮了大忙&#xff0c;就是使用起来较麻烦&#xff0c;于是&…

CodeReview的挑战

保证CodeReview质量的前提条件 有良性的社交压力 保证CodeReview质量的先决条件在于建立一个良性、有效的社交压力机制。这种机制始于招聘过程&#xff0c;我们需要吸引那些拥有基础专业素养的开发者&#xff0c;其中包括能够承受并积极响应CodeReview中社交压力的能力。 设想一…

微服务(基础篇-001-介绍、Eureka)

目录 认识微服务&#xff08;1&#xff09; 服务架构演变&#xff08;1.1&#xff09; 单体架构&#xff08;1.1.1&#xff09; 分布式架构&#xff08;1.1.2&#xff09; 微服务&#xff08;1.1.3&#xff09; 微服务结构 微服务技术对比 企业需求 SpringCloud(1.2) …