2022-06-03:a -> b,代表a在食物链中被b捕食,
给定一个有向无环图,返回这个图中从最初级动物到最顶级捕食者的食物链有几条。
来自理想汽车。

答案2022-06-03:

拓扑排序。

代码用rust编写。代码如下:

fn main() {
let sc: Vec<i32> = vec![5, 7, 1, 2, 1, 3, 2, 3, 3, 5, 2, 5, 4, 5, 3, 4];
let mut ii: i32 = 0;
while ii < sc.len() as i32 {
let mut info = GlobalInfo::new();
info.n = sc[ii as usize];
ii += 1;
let m: i32 = sc[ii as usize];
ii += 1;
let mut pre_edge: Vec<i32> = vec![];
let mut edges_to: Vec<i32> = vec![];
for _ in 0..m + 1 {
pre_edge.push(0);
edges_to.push(0);
}
for i in 1..=m {
let from = sc[ii as usize];
ii += 1;
let to = sc[ii as usize];
ii += 1;
edges_to[i as usize] = to;
pre_edge[i as usize] = info.head_edge[from as usize];
info.head_edge[from as usize] = i;
info.out0[from as usize] = true;
info.in0[to as usize] += 1;
}
let ans = how_many_ways(&mut pre_edge, &mut edges_to, &mut info);
println!("ans = {}", ans);
}
} pub struct GlobalInfo {
in0: Vec<i32>,
out0: Vec<bool>,
lines: Vec<i32>,
head_edge: Vec<i32>,
queue: Vec<i32>,
mod0: i32,
n: i32,
} impl GlobalInfo {
pub fn new() -> Self {
let mut in0: Vec<i32> = vec![];
let mut out0: Vec<bool> = vec![];
let mut lines: Vec<i32> = vec![];
let mut head_edge: Vec<i32> = vec![];
let mut queue: Vec<i32> = vec![];
let mod0: i32 = 80112002;
let n: i32 = 0;
for _i in 0..5001 {
in0.push(0);
out0.push(false);
lines.push(0);
head_edge.push(0);
queue.push(0);
}
Self {
in0,
out0,
lines,
head_edge,
queue,
mod0,
n,
}
}
} fn how_many_ways(pre_edge: &mut Vec<i32>, edges_to: &mut Vec<i32>, info: &mut GlobalInfo) -> i32 {
let mut ql = 0;
let mut qr = 0;
for i in 1..info.n {
if info.in0[i as usize] == 0 {
info.queue[qr as usize] = i;
qr += 1;
info.lines[i as usize] = 1;
}
}
while ql < qr {
let cur = info.queue[ql];
ql += 1;
let mut edge = info.head_edge[cur as usize];
while edge != 0 {
let next = edges_to[edge as usize];
info.lines[next as usize] =
(info.lines[next as usize] + info.lines[cur as usize]) % info.mod0;
info.in0[next as usize] -= 1;
if info.in0[next as usize] == 0 {
info.queue[qr] = next;
qr += 1;
}
edge = pre_edge[edge as usize];
}
}
let mut ans = 0;
for i in 1..=info.n {
if !info.out0[i as usize] {
ans = (ans + info.lines[i as usize]) % info.mod0;
}
}
return ans;
}

执行结果如下:


左神java代码

2022-06-03:a -> b,代表a在食物链中被b捕食, 给定一个有向无环图,返回这个图中从最初级动物到最顶级捕食者的食物链有几条。 来自理想汽车。的更多相关文章

  1. JuiceFS 在理想汽车的使用和展望

    理想汽车是中国新能源汽车制造商,设计.研发.制造和销售豪华智能电动汽车,于 2015 年 7 月创立,总部位于北京,已投产的自有生产基地位于江苏常州,通过产品创新及技术研发,为家庭用户提供安全及便捷的 ...

  2. Dapr中国社区活动之 分布式运行时开发者日 (2022.09.03)

    自2019年10月首次发布以来,Dapr(Distributed Application Runtime,分布式应用运行时)因其"更稳定"."更可靠".&quo ...

  3. 25条来自 Google 的移动网站设计准则

    越来越的用于通过移动设备访问网络,因此对于企业来说,现在比以往任何时候都更需要一个移动网站.但是,怎么样才能制作一个优秀的移动网站呢? 为了回答这个问题,Google 与 AnswerLab 合作,研 ...

  4. android 1.6 launcher研究之自定义ViewGroup (转 2011.06.03(二)——— android 1.6 launcher研究之自定义ViewGroup )

    2011.06.03(2)——— android 1.6 launcher研究之自定义ViewGroup2011.06.03(2)——— android 1.6 launcher研究之自定义ViewG ...

  5. 理想汽车 x JuiceFS:从 Hadoop 到云原生的演进与思考

    理想汽车在 Hadoop 时代的技术架构 首先简单回顾下大数据技术的发展,基于我个人的理解,将大数据的发展分了4个时期: 第一个时期: 2006 年到 2008 年.2008 年左右,Hadoop 成 ...

  6. 06. Matplotlib 2 |折线图| 柱状图| 堆叠图| 面积图| 填图| 饼图| 直方图| 散点图| 极坐标| 图箱型图

    1.基本图表绘制 plt.plot() 图表类别:线形图.柱状图.密度图,以横纵坐标两个维度为主同时可延展出多种其他图表样式 plt.plot(kind='line', ax=None, figsiz ...

  7. 算法战斗:给定一个号码与通配符问号W,问号代表一个随机数字。 给定的整数,得到X,和W它具有相同的长度。 问:多少整数协议W的形式和的比率X大?

    如果说: 给定一个号码与通配符问号W,问号代表一个随机数字. 给定的整数,得到X,和W它具有相同的长度. 问:多少整数协议W的形式和的比率X大? 进格公式 数据的多组,两排各数据的,W,第二行是X.它 ...

  8. 最短路径(给定一个包含非负整数的 m x n 网格,请找出一条从左上角到右下角的路径,使得路径上的数字总和为最小。 说明:每次只能向下或者向右移动一步。)

    给定一个包含非负整数的 m x n 网格,请找出一条从左上角到右下角的路径,使得路径上的数字总和为最小. 说明:每次只能向下或者向右移动一步. 例: 输入: [ [1,3,1], [1,5,1], [ ...

  9. 纯css使用线性渐变实现滚动进度条(来自于微信前端早读课)

    <!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8&quo ...

  10. JS中的prototype(原文地址:http://www.cnblogs.com/yjf512/archive/2011/06/03/2071914.html)

    JS中的phototype是JS中比较难理解的一个部分 本文基于下面几个知识点: 1 原型法设计模式 在.Net中可以使用clone()来实现原型法 原型法的主要思想是,现在有1个类A,我想要创建一个 ...

随机推荐

  1. 容器之beanfactory抽丝剥茧系列一

    1.总所周知,spring ioc功能实现的顶层接口就是BeanFactory.如下面类结构图 这张更加全面: 还有更加变态的 2.BeanFactory为最顶层接口,定义了最核心的需要实现的接口 p ...

  2. SAP transformation特殊字符

    unicode 0000 在transformation中总被翻译成,这个转义在其他语法中不存在,所以总是报错.

  3. 01. vim入门

    0. 前言 我打算写一个系列文章,用来详细介绍vim的使用技巧,我会从头开始,从vim入门,到vim的各种配置,这是第一篇 1. vim 的三种模式 Normal mode (正常模式) Inster ...

  4. Java笔记第九弹

    升级版: 数据安全问题的解决 1.同步代码块 (弊端:降低了运行效率) 格式:(锁--同一把锁) synchronized(任意对象){ 多条语句操作共享数据的代码 } //sellTicket.ja ...

  5. Java笔记第四弹

    File类创建功能 public boolean createNewFile();//当该文件名不存在时,创建一个由该抽象路径名命名的新空文件 public boolean mkdir();//创建由 ...

  6. 如何让excel不转换科学技术法

    使用场景: 业务部门从系统导出数据给开发人员,打开后数字全部变为科学计数法 参考文章:https://www.zhihu.com/question/20096750

  7. 使用Mathematica做序列的DTFT的几个例子

    ListFourierSequenceTransform[{-2, -1, 1, 3, 3, 1, -1, -2}, \[Omega]] ParametricPlot[{Re[%], Im[%]}, ...

  8. springboot 接入 ChatGPT

    项目地址 https://gitee.com/Kindear/lucy-chat 介绍 lucy-chat是接入OpenAI-ChatGPT大模型人工智能的Java解决方案,大模型人工智能的发展是不可 ...

  9. 协程 + epoll 的两个小例子

    getcontext/setupcontext/swapcontext/setcontext 方式的协程实现 #include <stdio.h> #include <stdlib. ...

  10. MyBatis 源码

    一.准备工作 MyBatis 工作流程:应用程序首先加载 mybatis-config.xml 配置文件,并根据配置文件的内容创建 SqlSessionFactory 对象:然后,通过 SqlSess ...