牛客NC314 体育课测验(一)【中等 图,BFS,拓扑排序 Java,Go、PHP】

题目

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

核心

图,BFS,拓扑排序,队列

参考答案Java

import java.util.*;public class Solution {/*** 代码中的类名、方法名、参数名已经指定,请勿修改,直接返回方法规定的值即可** * @param numProject int整型 * @param groups int整型ArrayList<ArrayList<>> * @return bool布尔型*/public boolean canFinish (int numProject, ArrayList<ArrayList<Integer>> groups) {//图,bfs,拓扑排序Map<Integer,GNode> graph = new HashMap<>();for (int i = 0; i <numProject ; i++) {graph.put(i,new GNode(i));}for (ArrayList<Integer> group : groups) {int vf = group.get(1);int tf = group.get(0);GNode fn = graph.get(vf);GNode tn = graph.get(tf);fn.nexts.add(tn);tn.in++;}Queue<GNode> q0 = new LinkedList<>();Set<Integer> visited = new HashSet<>();for(int k: graph.keySet()){if(graph.get(k).in==0){q0.add(graph.get(k));visited.add(graph.get(k).data);}}List<Integer> ll = new ArrayList<>();while (!q0.isEmpty()){int size = q0.size();for (int i = 0; i <size ; i++) {GNode pop = q0.poll();ll.add(pop.data);for (GNode next : pop.nexts) {if(--next.in==0){if(visited.contains(next.data)) return false; //出现环了q0.add(next);visited.add(next.data);}}}}return ll.size()  == numProject? true: false;}static class GNode{int data;int in;List<GNode> nexts;public GNode(int d){data =d;in =0;nexts = new ArrayList<>();}}
}

参考答案Go

package main/*** 代码中的类名、方法名、参数名已经指定,请勿修改,直接返回方法规定的值即可** * @param numProject int整型 * @param groups int整型二维数组 * @return bool布尔型
*/
func canFinish( numProject int ,  groups [][]int ) bool {//bfs,图,拓扑排序graph := map[int]*GNode{} //图for i := 0; i < numProject; i++ {graph[i] = &GNode{i, 0, []*GNode{}}}for _, v := range groups {vf := v[1]vt := v[0]nodef := graph[vf]nodet := graph[vt]nodet.in++nodef.nexts = append(nodef.nexts, nodet)}q0 := []*GNode{} //队列visted := map[int]bool{}for _, node := range graph {if node.in == 0 {q0 = append(q0, node)visted[node.data] = true}}ll := []int{}for len(q0) > 0 {size := len(q0)q0bak := []*GNode{}for i := 0; i < size; i++ {pop := q0[i]ll = append(ll, pop.data)for _, next := range pop.nexts {next.in--if next.in == 0 {_, ok := visted[next.data]if ok {return false //出现环了}q0bak = append(q0bak, next)visted[next.data] = true}}}q0 = q0bak}if len(ll) == numProject {return true}return false
}type GNode struct {data  intin    intnexts []*GNode
}

参考答案PHP

<?php/*** 代码中的类名、方法名、参数名已经指定,请勿修改,直接返回方法规定的值即可** * @param numProject int整型 * @param groups int整型二维数组 * @return bool布尔型*/
function canFinish( $numProject ,  $groups )
{//bfs, 图,拓扑排序$graph = [];for($i=0;$i<$numProject;$i++){$graph[$i] = new Node($i);}foreach ($groups as $v){$fv = $v[1];$tv = $v[0];$nodef = $graph[$fv];$nodet = $graph[$tv];$nodet->in++;$nodef->nexts[count($nodef->nexts)] = $nodet;}$q0 = [];$visited = [];foreach ($graph as $cur){if($cur->in ==0){$q0[count($q0)] = $cur;$visited[$cur->data] = true;}}$ll = [];while (count($q0) >0){$size = count($q0);$q0bak = [];for($i=0;$i<$size;$i++){$pop = $q0[$i];$ll[count($ll)] = $pop->data;foreach ($pop->nexts as $next){$next->in--;if($next->in ==0){if(isset($visited[$next->data])){return false; //出现环了}$q0bak[count($q0bak)] = $next;$visited[$next->data] =true;}}}$q0 =$q0bak;}return count($ll) ==$numProject? true:false;
}class Node{public $data;public $in;public $nexts;public function __construct($d){$this->data=$d;$this->in =0;$this->nexts = [];}
}

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

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

数据库——实验9 存储过程的使用

1. 存储过程的定义 存储过程是一系列预先编辑好的、能实现特定数据操作功能的SQL 代码集&#xff0c;它与特定的数据库相关联&#xff0c;存储在SQL Server服务器上。用户可以像使用自定义的函数一样重复调用这些存储过程&#xff0c;实现它所定义的操作。 2. 存储过程的类型…

A26 STM32_HAL库函数 之 IRDA通用驱动 -- A -- 所有函数的介绍及使用

A26 STM32_HAL库函数 之 IRDA通用驱动 -- A -- 所有函数的介绍及使用 1 该驱动函数预览1.1 HAL_IRDA_Init1.2 HAL_IRDA_DeInit1.3 HAL_IRDA_MspInit1.4 HAL_IRDA_MspDeInit1.5 HAL_IRDA_Transmit1.6 HAL_IRDA_Receive1.7 HAL_IRDA_Transmit_IT1.8 HAL_IRDA_Receive_IT1.9 HAL_I…

后台管理系统加水印(react)

效果 代码图片 代码 window.waterMark function (config) {var defaultConfig {content: 我是水印,fontSize: 16px,opacity: 0.3,rotate: -15,color: #ADADAD,modalId: J_waterMarkModalByXHMAndDHL,};config Object.assign({}, defaultConfig, config);var existMarkModal…

镜舟科技荣获金科创新社 2024 年度金融数据智能解决方案奖

近日&#xff0c; 镜舟科技凭借领先的金融实时数仓构建智能经营解决方案&#xff0c;在“金科创新社第六届金融数据智能优秀解决方案评选”活动中&#xff0c;成功入选“数据治理与数据平台创新优秀解决方案”榜单。 金科创新社主办的“鑫智奖”评选活动&#xff0c;旨在展示…

【解决】Caused by: javax.net.ssl.SSLHandshakeException: PKIX path building failed

问题原因&#xff1a; 在Java8及高版本以上的版本在源应用程序不信任目标应用程序的证书&#xff0c;因为在源应用程序的JVM信任库中找不到该证书或证书链。也就是目标站点启用了HTTPS 而缺少安全证书时出现的异常 解决方案&#xff1a; 我使用的是忽略证书验证 public clas…

【配电网故障定位】基于二进制矮猫鼬优化算法的配电网故障定位 33节点配电系统故障定位【Matlab代码#82】

文章目录 【获取资源请见文章第6节&#xff1a;资源获取】1. 配电网故障定位2. 二进制矮猫鼬优化算法3. 算例展示4. 部分代码展示5. 仿真结果展示6. 资源获取 【获取资源请见文章第6节&#xff1a;资源获取】 1. 配电网故障定位 配电系统故障定位&#xff0c;即在配电网络发生…

Day17-Python基础学习之设计模式

设计模式 单例模式 某些场景下&#xff0c;我们需要一个类无论获取多少次类对象&#xff0c;都仅仅提供一个具体的实例&#xff0c;用以节约创建对象的开销和内存开销 # 单例模式 class StrTools:pass ​ s1 StrTools() s2 StrTools() # 这里是两个独立对象 print(s1) pri…

vscode微博发布案例

样例: CSS代码: * {margin: 0;padding: 0; }ul{list-style: none; }.w {width: 900px;margin: 0 auto; }.controls textarea {width: 878px;height: 100px;resize: none;border-radius: 10px;outline: none;padding-left: 20px;padding-top: 10px;font-size: 18px; }.controls…

UE4 相机围绕某点旋转

关卡&#xff08;一个相机CameraActor&#xff0c;一个Cube(名叫Target)&#xff09;&#xff1a; 关卡蓝图里的逻辑(为了大家看得清楚&#xff0c;特意连得很紧凑&#xff0c;也比较乱&#xff0c;不然一张截图放不下)&#xff1a; 只对Yaw 只Pitch: 同样对Roll: 围绕任…

汇编语言——将BX中的无符号数和有符号数以二进制、八进制、十六进制、十进制形式输出

文章目录 将BX中的无符号数以二进制形式输出将BX中的无符号数以八进制形式输出将BX中的无符号数以十六进制形式输出将BX中的无符号数以十进制形式输出将BX中的有符号数以十进制形式输出 将BX中的无符号数以二进制形式输出 利用移位指令会影响CF&#xff0c;默认dl30h(数字0)&a…

基于Springboot的社区帮扶对象管理系统(有报告)。Javaee项目,springboot项目。

演示视频&#xff1a; 基于Springboot的社区帮扶对象管理系统&#xff08;有报告&#xff09;。Javaee项目&#xff0c;springboot项目。 项目介绍&#xff1a; 采用M&#xff08;model&#xff09;V&#xff08;view&#xff09;C&#xff08;controller&#xff09;三层体系…

软航H5 PDF签章产品经nginx代理之后浏览器中PDF盖章时提示:签章失败:网络错误 的问题排查及解决办法

目录 问题现象 问题排查思路 问题处理办法 附&#xff1a;软航H5 PDF签章产品介绍 软航电子签章系统 软航版式文档签批系统 问题现象 问题描述&#xff1a;在系统中集成了软航H5 PDF签章产品&#xff0c;软航H5 PDF签章产品的对应服务是通过nginx代理的&#xff0c;在奇安…

CDN的原理

CDN的原理 CDN的基本原理是依靠部署在各个区域大量缓存服务器的响应。当用户访问网站时&#xff0c;不需要访问站点的DNS服务器&#xff0c;而是利用全局负载技术将用户的请求直接指向最近的缓存服务器上&#xff0c;且保证服务器是正常工作的&#xff0c;访问的路径和内容是传…

leetcode199 二叉树的右视图

题目 给定一个二叉树的 根节点 root&#xff0c;想象自己站在它的右侧&#xff0c;按照从顶部到底部的顺序&#xff0c;返回从右侧所能看到的节点值。 示例 输入: [1,2,3,null,5,null,4] 输出: [1,3,4] 解析 这道题首先能想到的办法&#xff0c;就是使用迭代法层次遍历&…

jupyter简要使用手册

目录 1. 启动 Jupyter Notebook 服务器&#xff1a; 2. 创建新笔记本文件&#xff1a; 3. 编写和执行代码&#xff1a; 4. 插入和编辑单元格&#xff1a; 5. Markdown 单元格的使用&#xff1a; 6. 保存和下载笔记本文件&#xff1a; 7. 其他功能&#xff1a; 1. 启动 Ju…

【PyTorch Lightning】.ckpt 是什么?里面有什么?

什么是检查点&#xff08;checkpoint, ckpt&#xff09;&#xff1f; 当模型在训练过程中时&#xff0c;随着其不断接收更多数据&#xff0c;其性能也会发生变化。在训练过程中保存模型的状态是一种最佳实践。这样可以在开发模型的过程中&#xff0c;在每个关键点上获得模型的…

成为程序员后你都明白了程序即人生,并无二样

成为程序员后你都明白了什么&#xff1f; 简介&#xff1a;一个16年开发老兵的心路历程 方向一&#xff1a;技术成长 先说下本职吧&#xff0c;技术这一块呢。因为笔者非常喜欢技术从初二就开始接触简单的编程&#xff0c;考学时所有的专业全填写了计算机相关的专业&#xff0…

Spring Cloud+Uniapp 智慧工地云平台源码 智慧工地云平台AI视频分析应用

目录 AI应用与环境治理 设备管理与危大工程 塔吊安全监管 智慧工地APP端 智慧工地硬件设备 智慧工地主要功能模块 智慧工地可以通过以下几个方面为建筑行业赋能&#xff1a; 1.提高工程效率 2.提高工程安全性 3.提高工程质量 4.提高工程管理效率 绿色施工 质量管理…

PgSQL的登录相关(Ubuntu22.04)

一 将用户设为密码登录方式 1 修改用户的密码 sudo -u postgres psql -c "ALTER USER yuhui WITH PASSWORD xinmima;" 2 修改配置&#xff0c;指定用户yuhui使用密码登录 sudo vi /etc/postgresql/16/main/pg_hba.conf local all postgres …

遥感图像分割 | 基于一种类似UNet的Transformer算法实现遥感城市场景图像的语义分割_适用于卫星图像+航空图像+无人机图像

项目应用场景 面向遥感城市场景图像语义分割场景&#xff0c;项目采用类似 UNet 的 Transformer 深度学习算法来实现&#xff0c;项目适用于卫星图像、航空图像、无人机图像等。 项目效果 项目细节 > 具体参见项目 README.md (1) 安装依赖 conda create -n airs python3.8…