【NOIP2013普及组复赛】题4:车站分级

题4:车站分级

【题目描述】

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

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

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

【输入文件】

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

第 i + 1 i+1 i+1 行 ( 1 ≤ i ≤ m ) (1≤i≤m) (1≤i≤m)中,首先是一个正整数 s i ( 2 ≤ s i ≤ n ) si(2≤s_i≤n) si(2≤si≤n),表示第 i i i 趟车次有 s i s_i si 个停靠站;接下来有 s i s_i si 个正整数,表示所有停靠站的编号,从小到大排列。每两个数之间用一个空格隔开。输入保证所有的车次都满足要求。

【输出文件】

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

【输入样例1】

9 2

4 1 3 5 6

3 3 5 6

【输出样例1】

2

【输入样例2】

9 3

4 1 3 5 6

3 3 5 6

3 1 5 9

【输出样例2】

3

【数据范围】

对于 20 % 20\% 20% 的数据, 1 ≤ n , m ≤ 10 1≤n,m≤10 1≤n,m≤10;

对于 50 % 50\% 50% 的数据, 1 ≤ n , m ≤ 100 1≤n,m≤100 1≤n,m≤100;

对于 100 % 100\% 100% 的数据, 1 ≤ n , m ≤ 1000 1≤n,m≤1000 1≤n,m≤1000。

【代码如下】:

cpp 复制代码
#include <bits/stdc++.h>
using namespace std;
ifstream cin("level.in");
ofstream cout("level.out");
struct cs {
  int to, next;
} a[1000001];
int b[1001], f[1001], head[1001];
bool vi[1001][1001];
int n, m, x, y, z, ans, ll;
void init(int x, int y) {
  a[++ll].to = y;
  a[ll].next = head[x];
  head[x] = ll;
}
int dfs(int x) {
  for (int k = head[x]; k; k = a[k].next)
    if (!f[a[k].to])
      f[x] = max(f[x], dfs(a[k].to));
    else
      f[x] = max(f[x], f[a[k].to]);
  return ++f[x];
}
int main() {
  cin >> n >> m;
  for (int i = 1; i <= m; i++) {
    cin >> z;
    for (int i = 1; i <= z; i++) cin >> b[i];
    int l = 1;
    for (int i = b[1]; i < b[z]; i++) {
      if (b[l] == i) {
        l++;
        continue;
      } else {
        for (int k = 1; k <= z; k++) {
          if (!vi[b[k]][i]) {
            init(b[k], i);
            vi[b[k]][i] = 1;
          }
        }
      }
    }
  }
  for (int i = 1; i <= n; i++) {
    if (!f[i]) {
      ans = max(ans, dfs(i));
    }
  }
  cout << ans;
}
相关推荐
君义_noip2 小时前
CSP-J 2025 入门级 第一轮(初赛) 完善程序(1)
c++·算法·信息学奥赛·csp 第一轮
WL_Aurora2 小时前
备战蓝桥杯国赛【Day 6】
python·算法·蓝桥杯
绛橘色的日落(。・∀・)ノ2 小时前
机器学习 逻辑回归
算法·机器学习·逻辑回归
测绘第一深情2 小时前
在vscode中使用codex教程(个人安装经验)
数据结构·ide·vscode·python·算法·计算机视觉·编辑器
Liangwei Lin2 小时前
LeetCode 41. 缺失的第一个正数
数据结构·算法·leetcode
海参崴-2 小时前
手写红黑树全流程学习总结
学习·算法
名字不好奇2 小时前
大模型如何“理解“人类语言:从符号到语义的飞跃
算法
小雅痞2 小时前
[Java][Leetcode hard] 76. 最小覆盖子串
java·算法·leetcode
小O的算法实验室3 小时前
2026年IEEE TBD,面向大规模优化的随机矩阵粒子群算法,深度解析+性能实测
算法·论文复现·智能算法·智能算法改进
哭泣方源炼蛊3 小时前
AtCoder Beginner Contest 456 E补题(分层图 + 有向环检测 )
c++·算法·深度优先·图论·拓扑学