485拓扑结构图_拓扑图

485拓扑结构图_拓扑图一条单向的铁路线上 依次有编号为 1 2 n 的 n 个火车站 每个火车站都有一个级别 最低为 1 级 现有若干趟车次在这条线路上行驶 每一趟都满足如下要求 如果这趟车次停靠了火车站 x 则始发站 终点站之间所有级别大于等于火车站 x 的都必须停靠 注意 起始站和终点站自然也算作事先已知需要停靠的站点 例如 下表是 5 趟车次的运行情况 其中 前 4 趟车次均满足要求 而第

一条单向的铁路线上,依次有编号为 1, 2, …, n 的 n 个火车站。

每个火车站都有一个级别,最低为 1 级。

现有若干趟车次在这条线路上行驶,每一趟都满足如下要求:如果这趟车次停靠了火车站 x,则始发站、终点站之间所有级别大于等于火车站 x 的都必须停靠。(注意:起始站和终点站自然也算作事先已知需要停靠的站点)

例如,下表是 5 趟车次的运行情况。

其中,前 4 趟车次均满足要求,而第 5 趟车次由于停靠了 3 号火车站(2 级)却未停靠途经的 6 号火车站(亦为 2 级)而不满足要求。

现有 m 趟车次的运行情况(全部满足要求),试推算这 n 个火车站至少分为几个不同的级别。

输入格式
第一行包含 2 个正整数 n,m,用一个空格隔开。

第 i+1 行(1≤i≤m)中,首先是一个正整数 si(2≤si≤n),表示第 i 趟车次有 si 个停靠站;接下来有 si 个正整数,表示所有停靠站的编号,从小到大排列。

每两个数之间用一个空格隔开。输入保证所有的车次都满足要求。

输出格式
输出只有一行,包含一个正整数,即 n 个火车站最少划分的级别数。

数据范围
1≤n,m≤1000

输入样例:
9 3
4 1 3 5 6
3 3 5 6
3 1 5 9
输出样例:
3
#include
using namespace std;
const int N = 1e3 + 10;
int g[N][N],in[N];
int q[N],tt = 0,hh = 0;
const int INF = 0x3f3f3f3f;
int vis[N],ans[N],cnt;
int dist[N];
int main(){

int n,m;
cin>>n>>m;
int k,x;
for(int i = 0;i < m;i ++){

scanf("%d",&k);
memset(vis,0,sizeof vis);
cnt = 0;
int l = INF,r = 0;
for(int j = 0;j < k;j ++){

scanf("%d",&x);
vis[x] = true;
ans[cnt ++] = x;
}
for(int i = ans[0];i <= ans[cnt - 1];i ++){

if(!vis[i]){

for(int j = 0;j < cnt;j ++){

if(!g[i][ans[j]]){

g[i][ans[j]] = 1;
in[ans[j]] ++;
}
}
}
}
}
for(int i = 1;i <= n;i ++){

if(!in[i]){

q[tt ++] = i,dist[i] = 1;
}
}
int res = 1;
while(hh < tt){

int t = q[hh ++];
for(int i = 1;i <= n;i ++){

if(g[t][i]){

in[i] --;
if(!in[i]){

q[tt ++] = i;
}
if(dist[i] < dist[t] + 1){

dist[i] = dist[t] + 1;
res = max(res,dist[i]);
}
}
}
}
cout< return 0;
}
编程小号
上一篇 2025-02-08 11:46
下一篇 2025-03-04 17:51

相关推荐

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 举报,一经查实,本站将立刻删除。
如需转载请保留出处:https://bianchenghao.cn/hz/139004.html