首页 > 试题广场 >

基因调控网络

[编程题]基因调控网络
  • 热度指数:153 时间限制:C/C++ 3秒,其他语言6秒 空间限制:C/C++ 256M,其他语言512M
  • 算法知识视频讲解
在基因组学研究中,基因之间的调控关系可以被抽象成一个有向图,我们称之为基因调控网络
在这个网络中,每个节点代表一个基因,一条从基因 u 指向基因 v 的有向边表示基因 u 会激活基因 v

科学家们对一种被称为“协同调控模体”(Co-regulatory Motif)的特殊结构非常感兴趣。
一个协同调控模体由四个不同的基因 a, b, c, d 组成,它们需要满足以下激活关系:
1. 主调节基因 a 能够直接激活两个中间基因 bd
2. 这两个中间基因 bd 又都能直接激活同一个目标基因 c

简单来说,这个结构意味着存在两条从基因 a 到基因 c 的长度为 2 的不同路径,一条路径为 a \rightarrow b \rightarrow c,另一条为 a \rightarrow d \rightarrow c

给定一个基因调控网络的结构,请计算该网络中总共存在多少个这样的“协同调控模体”。

输入描述:
第一行包含两个整数 nm,使用空格隔开。
n 代表基因的数量(编号从 1n),m 代表已知的直接激活关系的数量。
接下来的 m 行,每行包含两个整数 u, v,表示存在一条从基因 u 到基因 v 的激活关系。

数据范围:1 \le n \le 10000 \le m \le 10000


输出描述:
输出一个整数,代表网络中“协同调控模体”的总数量。
示例1

输入

24 60
1 4
1 6
1 7
2 9
2 12
2 13
2 16
2 19
2 23
3 5
4 3
4 6
4 11
4 15
4 17
4 22
5 4
5 12
6 20
6 21
7 2
7 23
8 1
8 4
8 22
9 20
9 23
10 1
10 9
10 17
10 20
11 12
12 1
12 5
12 16
14 9
14 17
14 20
14 21
15 12
16 12
16 17
17 5
17 6
17 14
18 1
19 22
19 23
20 22
21 17
21 24
22 11
22 21
23 10
23 14
23 17
23 24
24 5
24 16
24 17

输出

20

备注:
本题由牛友@Charles 整理上传
头像 Silencer76
发表于 2025-10-24 13:35:31
题目链接 基因调控网络 题目描述 在一个基因调控网络(有向图)中,寻找一种名为“协同调控模体”的结构数量。 一个协同调控模体由四个不同的基因 组成,它们满足以下激活关系: 主调节基因 能直接激活两个中间基因 和 (即存在边 和 )。 这两个中间基因 和 又都能直接激活同一个目标基因 展开全文