【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) 1im中,首先是一个正整数 s i ( 2 ≤ s i ≤ n ) si(2≤s_i≤n) si2sin,表示第 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 1n,m10

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

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

【代码如下】:

#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));elsef[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;
}

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

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

相关文章

Q-Learning学习笔记-李宏毅

introduction 学习的并不是policy&#xff0c;而是学习critic&#xff0c;critic用来评价policy好还是不好&#xff1b;一种critic&#xff1a;state value function V π ( s ) V^\pi(s) Vπ(s)是给定一个policy π \pi π&#xff0c;在遇到state s s s之后累积的reward的…

狙击交易策略加强版与普通版5点区别,WeTrade众汇盘点

通过之前的文章想必各位投资者都已经知道了什么是狙击交易策略&#xff0c;以及如何使用&#xff0c;WeTrade众汇本着严谨的态度&#xff0c;对狙击战术进行了大致梳理&#xff0c;发现其主要更新集中在2015至2017年间。但是研发者并未止步于此。2018年之后&#xff0c;他们又推…

C++调用dll的方法

代码如下&#xff1a; #pragma once#include <Windows.h>using namespace std;class Test_ExportDll { public:typedef char* (_stdcall *Get_dll_versionPROC)(void);Get_dll_versionPROC Get_dll_version;typedef bool (_stdcall *Port_ClosePROC)(unsigned int Index…

子分支想主分支发起合并请求

请求合并 1.点击 git Web 页右上角打开 Merge requests 进入新页&#xff0c;点击右上角。注意选择要合并的项目 2.左边是源分支&#xff0c;右边是要合并的目标分支。 3.最后点击左下角绿色按钮 4.第一个红框 Assignee&#xff0c;选择要通知去合并的人。第二个红框不动&#…

Java面试题--基础篇,更新中...

1、 Java语言有哪些特点 简单易学、有丰富的类库 面向对象&#xff08;Java最重要的特性&#xff0c;让程序耦合度更低&#xff0c;内聚性更高&#xff09; 与平台无关性&#xff08;JVM是Java跨平台使用的根本&#xff09; 可靠安全 支持多线…

【shell】 break和continue的区别

break 是用于循环退出&#xff0c;而 continue 是结束本次循环&#xff0c;进入下一次循环。 1 break的使用 [rootopenEuler ~]# cat break.sh #!/bin/bashfor i in seq 9 doif [ $i -eq 5 ] ; thenbreakelseecho $ifi done [rootopenEuler ~]# bash break.sh 1 2 3 4 2 c…

Selenium的百度高级搜索-自动化(未完成)

from selenium import webdriver from selenium.webdriver import ActionChainsdriver webdriver.Chrome() driver.implicitly_wait(10) driver.maximize_window() driver.get("https://www.baidu.com/")# 鼠标悬停(难点) setting driver.find_element_by_id("…

【NPS】微软NPS配置802.1x,验证域账号,动态分配VLAN(WLC篇)

距离上一篇【NPS】微软NPS配置802.1x&#xff0c;验证域账号&#xff0c;动态分配VLAN&#xff08;NPS篇&#xff09;已经过去了近两周了&#xff0c;因为工作原因一直没有来得及更新在WLC上的设置&#xff0c;接下来我们来看一下如何在 Cisco Catalyst 9800-L Wireless Contro…

mysql实战——xtrabackup问题

备份恢复后启动不成功。 我测试了很多遍&#xff0c;最开始我以为备份后的数据文件没有pid造成的&#xff0c;所以一直测试 后来发现上图这样是正常的&#xff0c;mysqld_safe后就出现pid和sock文件 那启动失败的原因我认为是权限的问题&#xff0c;把数据文件目录权限全部设置…

golang websocket 发送消息莫名其妙断开的问题记录

概述 公司需要做个B/S架构的前端展示项目&#xff0c;当前以为是小case&#xff0c;但是在实现后端功能的时候&#xff0c;还是被坑了。 功能描述 项目需要实现的功能是调用外部第三方程序&#xff0c; 实时读取第三方程序的输出&#xff0c;发送到前端展示。因为懒得切换平…

使用Django框架搭建Web应用

文章目录 简介安装Django创建一个Django项目创建一个Django应用编写视图配置URL运行开发服务器总结与拓展数据库集成管理后台表单处理模板引擎安全性 简介 Django 是一款基于 Python 语言的开源 Web 应用框架&#xff0c;采用了 MVC&#xff08;模型-视图-控制器&#xff09;设…

Kubernetes 之 Deployment

Kubernetes 之 Deployment Deployment 定义 Deployment 是 Kubernetes 中最常用资源之一&#xff0c;为 ReplicaSet 和 Pod 的创建提供了一种声明式的定义方法。Kubernetes 通过定义一个Deployment 控制器会创建一个新的 ReplicaSet 资源&#xff0c;通过 ReplicaSet 资源创建…

初学者的终极SEO内容指南

为您的网站吸引自然流量是搜索引擎优化 &#xff08;SEO&#xff09; 的关键部分&#xff0c;而实现这一目标的最佳方法之一是通过 SEO 内容。 SEO内容采用优化最佳实践来帮助你的网站被搜索引擎注意到。但问题是&#xff0c;你如何写出好的SEO内容&#xff1f;这就是我们今天…

vue3 websocket实现心跳

实现场景 该需求是运用websocket进行网页之间通讯&#xff0c;同时保证websocket在通讯期间保持激活的状态。 功能分析 1、在websocket报错时&#xff0c;重新苏醒。 2、在websocket自动关闭时&#xff0c;重新连接。 3、在通讯期间&#xff0c;整个websocket能接受消息&#…

Redis 主从复制、哨兵与集群

一、Redis 主从复制 1. 主从复制的介绍 主从复制&#xff0c;是指将一台Redis服务器的数据&#xff0c;复制到其他的Redis服务器。前者称为主节点(Master)&#xff0c;后者称为从节点(Slave)&#xff1b;数据的复制是单向的&#xff0c;只能由主节点到从节点。 默认情况下&a…

现在的年轻人,怎么这么要脸?

从5月初到现在&#xff0c;在你的社交圈&#xff0c;一定看到过这样「灰头土脸」的照片吧&#xff01;从朋友圈到微博、到QQ、到Soul&#xff0c;一夜之间&#xff0c;小柴的社交圈像是刮了一场「沙尘暴」。 简直是「丑」到了所有人的心坎里&#xff01;所有人乐此不疲地把自己…

element plus校验日期格式为 type=“datetimerange“的方法

校验日期格式为数组格式时 :rules[{type:“arr”,…}] 失效 可以按照如下方法校验日期开始结束时间 rules: {planDate:[{type: "array",required: true,message: "请选择计划周期",trigger: "change",fields: {0: { type: "date", re…

java+Angular+Nginx+原生HTML+JS+CSS+Jquery融合B/S版电子病历系统云HIS系统源码

javaAngularNginx原生HTMLJSCSSJquery融合B/S版电子病历系统云HIS系统源码 Java版云HIS系统融合电子病历系统&#xff0c;是医学专用软件。医院通过电子病历以电子化方式记录患者就诊的信息&#xff0c;包括&#xff1a;首页、病程记录、检查检验结果、医嘱、手术记录、护理记录…

python 使用OCR 识别woff字体文件

做数据获取安**时发现请求返回的数据跟woff字体有关&#xff0c;这里写一个使用OCR识别方法&#xff0c; 1、重要部分的原理是解析woff文件&#xff0c;并将woff字体转为图片&#xff0c;并将字体编码与字体图片相对应&#xff0c;便于之后的数据解密解析。 2、使用的是muggl…

高性能推理框架漫谈

传统模型分布式推理框架 Tensorflow servingPytorch ServingTriton Server 大语言模型的推理框架 其中&#xff0c; VLLM 后端接入了Ray 框架&#xff0c; 作为调度请求的分发处理&#xff1b;除此之外&#xff0c;还包括Nvidia 最新推出的TensorRT-LLM&#xff0c; 增加了对…