牛客 2024 【牛客赛文X】春招冲刺 ONT73 体育课测验(二) 【中等 图/拓扑排序 Java,Go,PHP】

本文主要是介绍牛客 2024 【牛客赛文X】春招冲刺 ONT73 体育课测验(二) 【中等 图/拓扑排序 Java,Go,PHP】,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

题目

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

思路

图,BFS,队列

参考答案Java

import java.util.*;public class Solution {/*** 代码中的类名、方法名、参数名已经指定,请勿修改,直接返回方法规定的值即可*** @param numProject int整型* @param groups int整型ArrayList<ArrayList<>>* @return int整型ArrayList*/public ArrayList<Integer> findOrder (int numProject,ArrayList<ArrayList<Integer>> groups) {//map表示图Map<Integer, Gnode> graph = new HashMap<>();for (int i = 0; i < numProject ; i++) {graph.put(i, new Gnode(i));}for (ArrayList<Integer> group :groups) { //xxxf代表 开始节点  xxxt代表  f的邻居int vf = group.get(1);int vt = group.get(0);Gnode nodef = graph.get(vf);Gnode nodet = graph.get(vt);nodet.in++;nodef.nexts.add(nodet);}Queue<Gnode> q0 = new LinkedList<>();Set<Integer> set = new HashSet<>();for (Integer v : graph.keySet()) {if (graph.get(v).in == 0) {q0.add(graph.get(v));set.add(v);}}ArrayList<Integer> ll = new ArrayList<>();while (!q0.isEmpty()) {int size = q0.size();for (int i = 0; i < size ; i++) {Gnode cur = q0.poll();ll.add(cur.data);for (Gnode next : cur.nexts) {if (set.contains(next.data)) {return new ArrayList<>();//出现环了,直接返回空的ArrayList}if (--next.in == 0) {q0.add(next);set.add(next.data);}}}}return ll.size() == numProject ? ll : new ArrayList<>();}static class Gnode {int in;int data;List<Gnode> nexts;public Gnode(int d) {data = d;in = 0;nexts =  new ArrayList<>();}}
}

参考答案Go

package main/*** 代码中的类名、方法名、参数名已经指定,请勿修改,直接返回方法规定的值即可*** @param numProject int整型* @param groups int整型二维数组* @return int整型一维数组*/
func findOrder(numProject int, groups [][]int) []int {// map表示图graph := map[int]*Gnode{}for i := 0; i < numProject; i++ {graph[i] = &Gnode{i, 0, []*Gnode{}}}for _, gp := range groups {vf := gp[1] //出发vt := gp[0] //到达nodef := graph[vf]nodet := graph[vt]nodef.nexts = append(nodef.nexts, nodet) //增加邻居nodet.in++                               //入度+1}q0 := []*Gnode{} //Go中队列用切片来表示set := map[int]bool{}for _, v1 := range graph {if v1.in == 0 {q0 = append(q0, v1)set[v1.data] = true}}ll := []int{}for len(q0) > 0 {size := len(q0)q0bak := []*Gnode{}for i := 0; i < size; i++ {cur := q0[i]//_,ok:=set[cur.data]ll = append(ll, cur.data)for _, next := range cur.nexts {next.in--if next.in == 0 {_, ok := set[next.data]if ok {return []int{}}q0bak = append(q0bak, next)set[next.data] = true}}}q0 = q0bak}if len(ll) == numProject {return ll}return []int{}
}type Gnode struct { //图的节点data  intin    intnexts []*Gnode
}

参考答案PHP

<?php/*** 代码中的类名、方法名、参数名已经指定,请勿修改,直接返回方法规定的值即可** * @param numProject int整型 * @param groups int整型二维数组 * @return int整型一维数组*/
function findOrder( $numProject ,  $groups )
{// 图用map表示,PHP中数组是万能,数组也是java中的map,set,list$graph = array();for($i=0;$i<$numProject;$i++){$graph[$i] =  new Gnode($i);}foreach ($groups as $v){$vt= $v[0];$vf =$v[1];$nodet = $graph[$vt]; //出发节点$nodef = $graph[$vf]; //到达节点,也就是出发节点的邻居$nodet->in++;array_push( $nodef->nexts,$nodet);}//BFS$q0 = [];$set =[];foreach ($graph as $node){if($node -> in ==0){$q0[count($q0)] = $node; //放进入度为0的队列$set[$node->data] = $node->data; //访问过该节点了}}$ll = [];while (count($q0) >0){$size = count($q0);$q0bak = [];for($i=0;$i<$size;$i++){$cur =$q0[$i];$ll[count($ll)] = $cur->data;foreach ($cur->nexts as $next){$next->in--;if($next->in ==0){if(isset($set[$next->data])){return []; //出现环了}$q0bak[count($q0bak)] = $next;$set[$next->data] = $next->data;}}}$q0 =$q0bak;}if(count($ll) == $numProject){return $ll;}return [];
}class Gnode{public $in;public $data;public $nexts;public function __construct($d){$this->data = $d;$this->in =0;$this->nexts = [];}}

这篇关于牛客 2024 【牛客赛文X】春招冲刺 ONT73 体育课测验(二) 【中等 图/拓扑排序 Java,Go,PHP】的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/912844

相关文章

一文详解如何在idea中快速搭建一个Spring Boot项目

《一文详解如何在idea中快速搭建一个SpringBoot项目》IntelliJIDEA作为Java开发者的‌首选IDE‌,深度集成SpringBoot支持,可一键生成项目骨架、智能配置依赖,这篇文... 目录前言1、创建项目名称2、勾选需要的依赖3、在setting中检查maven4、编写数据源5、开启热

Java对异常的认识与异常的处理小结

《Java对异常的认识与异常的处理小结》Java程序在运行时可能出现的错误或非正常情况称为异常,下面给大家介绍Java对异常的认识与异常的处理,本文给大家介绍的非常详细,对大家的学习或工作具有一定的参... 目录一、认识异常与异常类型。二、异常的处理三、总结 一、认识异常与异常类型。(1)简单定义-什么是

SpringBoot项目配置logback-spring.xml屏蔽特定路径的日志

《SpringBoot项目配置logback-spring.xml屏蔽特定路径的日志》在SpringBoot项目中,使用logback-spring.xml配置屏蔽特定路径的日志有两种常用方式,文中的... 目录方案一:基础配置(直接关闭目标路径日志)方案二:结合 Spring Profile 按环境屏蔽关

Java使用HttpClient实现图片下载与本地保存功能

《Java使用HttpClient实现图片下载与本地保存功能》在当今数字化时代,网络资源的获取与处理已成为软件开发中的常见需求,其中,图片作为网络上最常见的资源之一,其下载与保存功能在许多应用场景中都... 目录引言一、Apache HttpClient简介二、技术栈与环境准备三、实现图片下载与保存功能1.

SpringBoot排查和解决JSON解析错误(400 Bad Request)的方法

《SpringBoot排查和解决JSON解析错误(400BadRequest)的方法》在开发SpringBootRESTfulAPI时,客户端与服务端的数据交互通常使用JSON格式,然而,JSON... 目录问题背景1. 问题描述2. 错误分析解决方案1. 手动重新输入jsON2. 使用工具清理JSON3.

java中long的一些常见用法

《java中long的一些常见用法》在Java中,long是一种基本数据类型,用于表示长整型数值,接下来通过本文给大家介绍java中long的一些常见用法,感兴趣的朋友一起看看吧... 在Java中,long是一种基本数据类型,用于表示长整型数值。它的取值范围比int更大,从-922337203685477

java Long 与long之间的转换流程

《javaLong与long之间的转换流程》Long类提供了一些方法,用于在long和其他数据类型(如String)之间进行转换,本文将详细介绍如何在Java中实现Long和long之间的转换,感... 目录概述流程步骤1:将long转换为Long对象步骤2:将Longhttp://www.cppcns.c

SpringBoot集成LiteFlow实现轻量级工作流引擎的详细过程

《SpringBoot集成LiteFlow实现轻量级工作流引擎的详细过程》LiteFlow是一款专注于逻辑驱动流程编排的轻量级框架,它以组件化方式快速构建和执行业务流程,有效解耦复杂业务逻辑,下面给大... 目录一、基础概念1.1 组件(Component)1.2 规则(Rule)1.3 上下文(Conte

SpringBoot服务获取Pod当前IP的两种方案

《SpringBoot服务获取Pod当前IP的两种方案》在Kubernetes集群中,SpringBoot服务获取Pod当前IP的方案主要有两种,通过环境变量注入或通过Java代码动态获取网络接口IP... 目录方案一:通过 Kubernetes Downward API 注入环境变量原理步骤方案二:通过

Springboot整合Redis主从实践

《Springboot整合Redis主从实践》:本文主要介绍Springboot整合Redis主从的实例,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录前言原配置现配置测试LettuceConnectionFactory.setShareNativeConnect