牛客 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

相关文章

springboot集成easypoi导出word换行处理过程

《springboot集成easypoi导出word换行处理过程》SpringBoot集成Easypoi导出Word时,换行符n失效显示为空格,解决方法包括生成段落或替换模板中n为回车,同时需确... 目录项目场景问题描述解决方案第一种:生成段落的方式第二种:替换模板的情况,换行符替换成回车总结项目场景s

SpringBoot集成redisson实现延时队列教程

《SpringBoot集成redisson实现延时队列教程》文章介绍了使用Redisson实现延迟队列的完整步骤,包括依赖导入、Redis配置、工具类封装、业务枚举定义、执行器实现、Bean创建、消费... 目录1、先给项目导入Redisson依赖2、配置redis3、创建 RedissonConfig 配

SpringBoot中@Value注入静态变量方式

《SpringBoot中@Value注入静态变量方式》SpringBoot中静态变量无法直接用@Value注入,需通过setter方法,@Value(${})从属性文件获取值,@Value(#{})用... 目录项目场景解决方案注解说明1、@Value("${}")使用示例2、@Value("#{}"php

SpringBoot分段处理List集合多线程批量插入数据方式

《SpringBoot分段处理List集合多线程批量插入数据方式》文章介绍如何处理大数据量List批量插入数据库的优化方案:通过拆分List并分配独立线程处理,结合Spring线程池与异步方法提升效率... 目录项目场景解决方案1.实体类2.Mapper3.spring容器注入线程池bejsan对象4.创建

线上Java OOM问题定位与解决方案超详细解析

《线上JavaOOM问题定位与解决方案超详细解析》OOM是JVM抛出的错误,表示内存分配失败,:本文主要介绍线上JavaOOM问题定位与解决方案的相关资料,文中通过代码介绍的非常详细,需要的朋... 目录一、OOM问题核心认知1.1 OOM定义与技术定位1.2 OOM常见类型及技术特征二、OOM问题定位工具

PHP轻松处理千万行数据的方法详解

《PHP轻松处理千万行数据的方法详解》说到处理大数据集,PHP通常不是第一个想到的语言,但如果你曾经需要处理数百万行数据而不让服务器崩溃或内存耗尽,你就会知道PHP用对了工具有多强大,下面小编就... 目录问题的本质php 中的数据流处理:为什么必不可少生成器:内存高效的迭代方式流量控制:避免系统过载一次性

基于 Cursor 开发 Spring Boot 项目详细攻略

《基于Cursor开发SpringBoot项目详细攻略》Cursor是集成GPT4、Claude3.5等LLM的VSCode类AI编程工具,支持SpringBoot项目开发全流程,涵盖环境配... 目录cursor是什么?基于 Cursor 开发 Spring Boot 项目完整指南1. 环境准备2. 创建

Spring Security简介、使用与最佳实践

《SpringSecurity简介、使用与最佳实践》SpringSecurity是一个能够为基于Spring的企业应用系统提供声明式的安全访问控制解决方案的安全框架,本文给大家介绍SpringSec... 目录一、如何理解 Spring Security?—— 核心思想二、如何在 Java 项目中使用?——

SpringBoot+RustFS 实现文件切片极速上传的实例代码

《SpringBoot+RustFS实现文件切片极速上传的实例代码》本文介绍利用SpringBoot和RustFS构建高性能文件切片上传系统,实现大文件秒传、断点续传和分片上传等功能,具有一定的参考... 目录一、为什么选择 RustFS + SpringBoot?二、环境准备与部署2.1 安装 RustF

springboot中使用okhttp3的小结

《springboot中使用okhttp3的小结》OkHttp3是一个JavaHTTP客户端,可以处理各种请求类型,比如GET、POST、PUT等,并且支持高效的HTTP连接池、请求和响应缓存、以及异... 在 Spring Boot 项目中使用 OkHttp3 进行 HTTP 请求是一个高效且流行的方式。