news 2025/12/22 18:49:18

打卡信奥刷题(2521)用C++实现信奥 P1983 [NOIP 2013 普及组] 车站分级

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
打卡信奥刷题(2521)用C++实现信奥 P1983 [NOIP 2013 普及组] 车站分级

P1983 [NOIP 2013 普及组] 车站分级

题目背景

NOIP2013 普及组 T4

题目描述

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

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

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

输入格式

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

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

输出格式

一个正整数,即nnn个火车站最少划分的级别数。

输入输出样例 #1

输入 #1

9 2 4 1 3 5 6 3 3 5 6

输出 #1

2

输入输出样例 #2

输入 #2

9 3 4 1 3 5 6 3 3 5 6 3 1 5 9

输出 #2

3

说明/提示

对于 $ 20%$ 的数据,1≤n,m≤101 ≤ n, m ≤ 101n,m10

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

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

C++实现

#include<iostream>#include<cstdio>#include<cstring>#defineZYS1005usingnamespacestd;intn,m,ans,st[ZYS],s,tuopu[ZYS][ZYS],de[ZYS],tt[ZYS],top;boolis[ZYS],bo[ZYS];//用andyzys大佬的名字做数组范围intmain(){scanf("%d %d",&n,&m);for(inti=1;i<=m;i++){memset(is,0,sizeof(is));//is表示是否是停靠站scanf("%d",&s);for(intj=1;j<=s;j++)scanf("%d",&st[j]),is[st[j]]=true;for(intj=st[1];j<=st[s];j++)if(!is[j])//枚举站点,若不是已停靠的就小于所有停靠站的等级for(intk=1;k<=s;k++)//枚举已停靠站点if(!tuopu[j][st[k]])tuopu[j][st[k]]=1,de[st[k]]++;//tuopu[i][j]表示j>i的级别,如上}do{top=0;for(inti=1;i<=n;i++)if(de[i]==0&&!bo[i]){tt[++top]=i,bo[i]=true;//开始将出度为0的点删掉}for(inti=1;i<=top;i++)for(intj=1;j<=n;j++)if(tuopu[tt[i]][j])tuopu[tt[i]][j]=0,de[j]--;//去边去点ans++;}while(top);printf("%d",ans-1);//最后一次什么点都没有会多算一次(自行理解)return0;}

后续

接下来我会不断用C++来实现信奥比赛中的算法题、GESP考级编程题实现、白名单赛事考题实现,记录日常的编程生活、比赛心得,感兴趣的请关注,我后续将继续分享相关内容

版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2025/12/22 12:54:44

Dify与Spring AI集成难题一网打尽,资深架构师亲授生产级解决方案

第一章&#xff1a;Dify与Spring AI集成概述Dify 作为一款面向 AI 应用开发的低代码平台&#xff0c;提供了可视化编排、模型管理与 API 服务发布能力。Spring AI 是 Spring 生态中用于简化人工智能应用开发的框架&#xff0c;支持与主流大模型平台对接。将 Dify 与 Spring AI …

作者头像 李华
网站建设 2025/12/22 10:20:59

学习笔记——Makefile

基本概念 Makefile 是工程管理工具&#xff0c;用于编译多个源文件&#xff08;可能在不同目录下&#xff09;&#xff0c;可以添加编译选项。 基本语法规则 makefile 目标: 依赖 [TAB] 规则命令 版本演进 版本1&#xff1a;直接编译 makefile a.out: main.c func.cgcc…

作者头像 李华
网站建设 2025/12/17 17:24:14

【必看收藏】2026大模型校招趋势:5.2W月薪岗位揭秘,AI人才就业指南

2026年AI人才校招市场呈现显著扩张趋势&#xff0c;大模型算法岗位月薪可达5.2万&#xff0c;顶尖人才薪资翻倍。高科技企业(60%)比金融行业(40.1%)更重视AI人才&#xff0c;近六成企业计划扩招。企业更看重数学与算法基础(60.3%)和项目实践(52.5%)&#xff0c;名校学历重要性下…

作者头像 李华
网站建设 2025/12/22 14:21:35

MMSA框架:多模态情感分析的终极指南与实战应用

MMSA框架&#xff1a;多模态情感分析的终极指南与实战应用 【免费下载链接】MMSA MMSA is a unified framework for Multimodal Sentiment Analysis. 项目地址: https://gitcode.com/gh_mirrors/mm/MMSA 在人工智能快速发展的今天&#xff0c;多模态情感分析正成为理解人…

作者头像 李华
网站建设 2025/12/22 10:20:43

Markdowner:网站内容秒变AI友好Markdown的终极神器

还在为网站内容整理发愁吗&#xff1f;Markdowner来帮你&#xff01;这个强大的开源工具能够将任何网站瞬间转换为适合大型语言模型处理的Markdown格式数据&#xff0c;让你的AI应用更智能、更高效。 【免费下载链接】markdowner A fast tool to convert any website into LLM-…

作者头像 李华
网站建设 2025/12/11 18:33:36

如何扛住《珠江》所有拍摄考验?幕后8K设备实力揭晓

珠江&#xff0c;一条承载着千年商贸与人文记忆的水道&#xff0c;其纪录片拍摄始终面临着独特挑战——变幻的光线、复杂的水汽环境、需要同时捕捉的宏大场景与精微细节。当拍摄团队决定采用博冠8K摄像机完成这一项目时&#xff0c;这既是对设备性能的一次高强度检验&#xff0…

作者头像 李华