CSP-J2024 全网首发

                                                        T1:扑克牌

题目描述 Description

小 P 从同学小 Q 那儿借来一副 n 张牌的扑克牌。
本题中我们不考虑大小王,此时每张牌具有两个属性:花色和点数。花色共有 4种:
方片、草花、红桃和黑桃。点数共有 13 种,从小到大分别为A 2 3 4 5 6 7 8 9 T J Q K。注意:点数 10 在本题中记为 T。
我们称一副扑克牌是完整的,当且仅当对于每一种花色和每一种点数,都恰好有一张牌具有对应的花色和点数。由此,一副完整的扑克牌恰好有4x13=52 张牌。以下图片展示了一副完整的扑克牌里所有的 52 张牌:


小P借来的牌可能不是完整的,为此小P准备再向同学小S借若干张牌。可以认为小S每种牌都有无限张,因此小P可以任意选择借来的牌。小P想知道他至少得向小S借多少张牌,才能让从小S和小Q借来的牌中,可以选出 52 张牌构成一副完整的扑克牌。
为了方便你的输入,我们使用字符D代表方片,字符C代表草花,字符H代表红桃,字符S代表黑桃,这样每张牌可以通过一个长度为2的字符串表示,其中第一个字符表示这张牌的花色,第二个字符表示这张牌的点数,例如 CA 表示草花 A,ST 表示黑桃 T(黑桃 10)。

输入描述 Input Description

从文件 poker.in 中读入数据。
输入的第一行包含一个整数 n 表示牌数。
接下来 n 行:
每行包含一个长度为 2 的字符串描述一张牌,其中第一个字符描述其花色,第二个字符描述其点数。

输出描述 Output Description

输出到文件 poker.out 中。
输出一行一个整数,表示最少还需要向小 S 借几张牌才能凑成一副完整的扑克牌。

样例输入 Sample Input

样例输入1 1 SA 样例输入2 4 DQ H3 DQ DT

样例输出 Sample Output

样例输出1 51 样例输出2 49

数据范围及提示 Data Size & Hint

【样例 1 解释】
这一副牌中包含一张黑桃 A,小 P 还需要借除了黑桃 A 以外的 51 张牌以构成一副完整的扑克牌。
【样例 2 解释】
这一副牌中包含两张方片 Q、一张方片 T(方片 10)以及一张红桃 3,小 P 还需要借除了红桃 3、方片 T 和方片 Q 以外的 49 张牌。
【数据范围】
对于所有测试数据,保证:1≤n≤52,输入的n个字符串每个都代表一张合法的扑克牌,即字符串长度为 2,且第一个字符为D C H S中的某个字符,第二个字符为A 2 3 4 5 6 7 8 9 T J Q K中的某个字符

特殊性质 A:保证输入的 n 张牌两两不同。
特殊性质 B:保证所有牌按照点数从小到大依次输入,点数相同时按照方片、草花、红桃、黑桃的顺序依次输入

T2:地图探险

题目描述 Description

  小 A 打算前往一片丛林去探险。丛林的地理环境十分复杂,为了防止迷路,他先派遣了一个机器人前去探路。
  丛林的地图可以用一个 n 行 m 列的字符表来表示。我们将第 i 行第 j 列的位置的坐标记作 ( i , j ) (1 ≤ i ≤ n, 1 ≤ j ≤ m)。如果这个位置的字符为 x,即代表这个位置上有障碍,不可通过。反之,若这个位置的字符为 . ,即代表这个位置是一片空地,可以通过。
  这个机器人的状态由位置和朝向两部分组成。其中位置由坐标 (x, y)(1 ≤ x ≤ n, 1 ≤ y ≤ m) 刻画,它表示机器人处在地图上第 x 行第 y 列的位置。而朝向用一个 0 ∼ 3 的整数 d 表示,其中 d = 0 代表向东,d = 1 代表向南,d = 2 代表向西,d = 3 代表向北。
  初始时,机器人的位置为 (x0, y0),朝向为 d0。保证初始时机器人所在的位置为空地。 接下来机器人将要进行 k 次操作。每一步,机器人将按照如下的模式操作:

  1. 假设机器人当前处在的位置为 (x, y),朝向为 d。则它的方向上的下一步的位置 (x′, y′) 定义如下:若 d = 0,则令 (x′, y′) = (x, y + 1),若 d = 1,则令 (x′, y′) = (x + 1, y),若 d = 2,则令 (x′, y′) =(x, y − 1),若 d = 3,则令(x′, y′) = (x − 1, y)。
  2. 接下来,机器人判断它下一步的位置是否在地图内,且是否为空地。具体地说,它判断 (x′, y′) 是否满足 1 ≤ x′ ≤ n, 1 ≤ y′ ≤ m,且 (x′, y′) 位置上是空地。如果条件成立,则机器人会向前走一步。它新的位置变为 (x′, y′),且朝向不变。如果条件不成立,则它会执行“向右转”操作。也就是说,令 d′ = (d + 1) mod 4(即 d + 1 除以 4 的余数),且它所处的位置保持不变,但朝向由 d 变为 d′。
      小 A 想要知道,在机器人执行完 k 步操作之后,地图上所有被机器人经过的位置(包括起始位置)有几个。

输入描述 Input Description

本题有多组测试数据。
输入的第一行包含一个正整数 T,表示数据组数。
接下来包含 T 组数据,每组数据的格式如下:
第一行包含三个正整数 n, m, k。其中 n, m 表示地图的行数和列数,k 表示机器人执行操作的次数。
第二行包含两个正整数 x0, y0 和一个非负整数 d0。
接下来 n 行,每行包含一个长度为 m 的字符串。保证字符串中只包含 x 和 . 两个字符。其中,第 x 行的字符串的第 y 个字符代表的位置为 (x, y)。这个位置是 x 即代表它是障碍,否则代表它是空地。数据保证机器人初始时所在的位置为空地。

输出描述 Output Description

对于每组数据:输出一行包含一个正整数,表示地图上所有被机器人经过的位置(包括起始位置)的个数。

样例输入 Sample Input

2 1 5 4 1 1 2 ....x 5 5 20 1 1 0 ..... .xxx. .x.x. ..xx. x....

样例输出 Sample Output

3 13

数据范围及提示 Data Size & Hint

该样例包含两组数据。
对第一组数据,机器人的状态以如下方式变化:

  1. 初始时,机器人位于位置 (1, 1),方向朝西(用数字 2 代表)。
  2. 第一步,机器人发现它下一步的位置 (1, 0) 不在地图内,因此,它会执行“向右
    转”操作。此时,它的位置仍然为 (1, 1),但方向朝北(用数字 3 代表)。
  3. 第二步,机器人发现它下一步的位置 (0, 1) 不在地图内,因此,它仍然会执行“向
    右转”操作。此时,它的位置仍然为 (1, 1),但方向朝东(用数字 0 代表)。
  4. 第三步,机器人发现它下一步的位置 (1, 2) 在地图内,且为空地。因此,它会向
    东走一步。此时,它的位置变为 (1, 2),方向仍然朝东。
  5. 第四步,机器人发现它下一步的位置 (1, 3) 在地图内,且为空地。因此,它会向
    东走一步。此时,它的位置变为 (1, 3),方向仍然朝东。
    因此,四步之后,机器人经过的位置有三个,分别为 (1, 1),(1, 2),(1, 3)。

对第二组数据,机器人依次执行的操作指令为:向东走到 (1, 2),向东走到 (1, 3),
向东走到 (1, 4),向东走到 (1, 5),向右转,向南走到 (2, 5),向南走到 (3, 5),向南走到
(4, 5),向南走到 (5, 5),向右转,向西走到 (5, 4),向西走到 (5, 3),向西走到 (5, 2),向
右转,向北走到 (4, 2),向右转,向右转,向南走到 (5, 2),向右转,向右转。

对于所有测试数据,保证:1 ≤ T ≤ 5, 1 ≤ n, m ≤ 103, 1 ≤ k ≤ 106, 1 ≤ x0 ≤ n, 1 ≤y0 ≤ m, 0 ≤ d0 ≤ 3,且机器人的起始位置为空地。

T3:小木棍

题目描述 Description

小S喜欢收集小木棍。在收集了n根长度相等的小木棍之后,他闲来无事,便用它们拼起了数字。用小木棍拼每种数字的方法如下图所示。


现在小S希望拼出一个正整数,满足如下条件:
•拼出这个数恰好使用n根小木棍;
•拼出的数没有前导0;
•在满足以上两个条件的前提下,这个数尽可能小。
小S想知道这个数是多少,可n很大,把木棍整理清楚就把小S折腾坏了,所以你需要帮他解决这个问题。如果不存在正整数满足以上条件,你需要输出‐1进行报告。

输入描述 Input Description

从文件sticks.in中读入数据。
本题有多组测试数据。
输入的第一行包含一个正整数T,表示数据组数。
接下来包含T组数据,每组数据的格式如下:
一行包含一个整数n,表示木棍数。

输出描述 Output Description

输出到文件 sticks.out 中。
对于每组数据:输出一行,如果存在满足题意的正整数,输出这个数;否则输出 ‐1。

样例输入 Sample Input

5 1 2 3 6 18

样例输出 Sample Output

-1 1 7 6 208

数据范围及提示 Data Size & Hint

•对于第一组测试数据,不存在任何一个正整数可以使用恰好一根小木棍摆出,故输出‐1。
•对于第四组测试数据,注意0并不是一个满足要求的方案。摆出9、41以及111都恰好需要6根小木棍,但它们不是摆出的数最小的方案。
•对于第五组测试数据,摆出208需要5+6+7=18根小木棍。可以证明摆出任何一个小于208的正整数需要的小木棍数都不是18。注意尽管拼出006也需要18根小木棍,但因为这个数有前导零,因此并不是一个满足要求的方案。
【数据范围】
对于所有测试数据,保证:1<=T<=50,1<=n<=105


特殊性质A:保证n是7的倍数且n>=100。
特殊性质B:保证存在整数k使得n=7k+1,且n≥100。

T4:接龙

题目描述 Description

在玩惯了成语接龙之后,小J和他的朋友们发明了一个新的接龙规则。
总共有n个人参与这个接龙游戏,第i个人会获得一个整数序列Si作为他的词库。
一次游戏分为若干轮,每一轮规则如下:

  • n个人中的某个人p带着他的词库Sp进行接龙。若这不是游戏的第一轮,那么这一轮进行接龙的人不能与上一轮相同,但可以与上上轮或更往前的轮相同。
  • 接龙的人选择一个长度在[2,k]的Sp的连续子序列 A 作为这一轮的接龙序列,其中k是给定的常数。若这是游戏的第一轮,那么 A需要以元素1开头,否则A 需要以上一轮的接龙序列的最后一个元素开头。
    ------序列 A是序列S的连续子序列当且仅当可以通过删除 S的开头和结尾的若干元素(可以不删除)得到 4。

为了强调合作,小J给了n个参与游戏的人q个任务,第j个任务需要这 n个人进行一次游戏,在这次游戏里进行恰好rj轮接龙,且最后一轮的接龙序列的最后一个元素恰好为 cj。为了保证任务的可行性,小J请来你判断这q个任务是否可以完成的,即是否存在一个可能的游戏过程满足任务条件。

输入描述 Input Description

从文件 chain.in 中读入数据。
本. 题. 有. 多. 组. 测. 试. 数. 据。.
输入的第一行包含一个正整数 T,表示数据组数。
接下来包含 T 组数据,每组数据的格式如下:
第一行包含三个整数 n, k, q,分别表示参与游戏的人数、接龙序列长度上限以及任务个数。
接下来 n 行:
第 i 行包含 (li + 1) 个整数 li, Si,1, Si,2, · · · , Si,li,其中第一个整数 li 表示序列 Si的长度,接下来 li 个整数描述序列 Si。
接下来 q 行:
第 j 行包含两个整数 rj, cj,描述一个任务。

输出描述 Output Description

输出到文件 chain.out 中。
对于每个任务:输出一行包含一个整数,若任务可以完成输出 1,否则输出 0。

样例输入 Sample Input

1 3 3 7 5 1 2 3 4 1 3 1 2 5 3 5 1 6 1 2 1 4 2 4 3 4 6 6 1 1 7 7

样例输出 Sample Output

1 0 1 0 1 0 0

数据范围及提示 Data Size & Hint

【样例一解释】
在下文中,我们使用{Ai}= {A1,A2,…,Ar}表示一轮游戏中所有的接龙序列{pi}= {p1,p2,…,pr}表示对应的接龙的人的编号。由于所有字符均为一位数字,为了方便我们直接使用数字字符串表示序列。

  • 对于第一组询问,p1=1、A1= 12 是一个满足条件的游戏过程。
  • 对于第二组询问,可以证明任务不可完成。注意p1=1、A1= 1234 不是合法的游戏过程,因为时|A1|=4>k。
  • 对于第三组询问,{pi}={2,1}、{Ai}= {12,234}是一个满足条件的游戏过程。
  • 对于第四组询问,可以证明任务不可完成。注意 {pi={2,1,1}、{Ai}= {12,23,34}不是一个合法的游戏过程,因为尽管所有的接龙序列长度均不超过k,但第二轮
    和第三轮由同一个人接龙,不符合要求。
  • 对于第五组询问,{pi}={1,2,3,1,2,3}、{Ai}= {12,25,51,12,25,516}是一个满足条件的游戏过程。
  • 对于第六组询问,可以证明任务不可完成。注意每个接龙序列的长度必须大于等于 2,因此 A1=1不是一个合法的游戏过程。
  • 对于第七组询问,所有人的词库均不存在字符7,因此任务显然不可完成。

【数据范围】
对于所有测试数据,保证:
·1≤T≤5;
·1≤n≤105,2≤k≤2x105,1≤q≤105;
·1≤li<2x105,1≤Si,j≤2x105;
·1≤rj<100,1≤cj≤2x105;
·设Σl为单组测试数据内所有li的和,则Σl≤2x105。


特殊性质 A:保证k=2x105。
特殊性质 B:保证 k≤ 5。
特殊性质C:保证在单组测试数据中,任意一个字符在词库中出现次数之和均不超
过 5。

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

如若内容造成侵权/违法违规/事实不符,请联系我们进行投诉反馈qq邮箱809451989@qq.com,一经查实,立即删除!

相关文章

【3DMAX科研绘图】3DMAX饼状图生成插件PieChart使用方法详解

3DMAX饼状图生成插件PieChart&#xff0c;一款用于制作3D饼状图的工具。可以设置任意数量的切片&#xff0c;以及随机或指定切片颜色。 饼状图&#xff08;Pie Chart&#xff09;是一种常用的数据可视化工具&#xff0c;它主要用于展示不同类别数据的比例关系。在饼状图中&…

ERPS环网配置

ERPS&#xff08;Ethernet Ring Protection Switching&#xff09;&#xff1a;以太网多环保护技术 ERPS节点信息 1、RPL owner 节点&#xff08;主节点&#xff09; 一个 ERPS 环只有一个 RPL owner 节点&#xff0c;由用户配置决定&#xff0c;通过阻塞 RPL 端口来防止 ERP…

.NET 一款内网渗透中替代PowerShell的工具

01阅读须知 此文所提供的信息只为网络安全人员对自己所负责的网站、服务器等&#xff08;包括但不限于&#xff09;进行检测或维护参考&#xff0c;未经授权请勿利用文章中的技术资料对任何计算机系统进行入侵操作。利用此文所提供的信息而造成的直接或间接后果和损失&#xf…

笔记整理—linux驱动开发部分(1)驱动梗概

驱动可以分为广义上的和狭义上的驱动。广义上的驱动是用于操作硬件的代码&#xff0c;而狭义上的驱动为基于内核系统之上让硬件去被操作的逻辑方法。 linux体系架构&#xff1a; 1.分层思想 &#xff1a;在OS中间还会有许多层。 : 2.驱动的上面是系统调用&#xff08;API&…

Springboot 整合 Java DL4J 实现智能客服

&#x1f9d1; 博主简介&#xff1a;历代文学网&#xff08;PC端可以访问&#xff1a;https://literature.sinhy.com/#/literature?__c1000&#xff0c;移动端可微信小程序搜索“历代文学”&#xff09;总架构师&#xff0c;15年工作经验&#xff0c;精通Java编程&#xff0c;…

大语言模型的Scaling Law【Power Low】

NLP-大语言模型学习系列目录 一、注意力机制基础——RNN,Seq2Seq等基础知识 二、注意力机制【Self-Attention,自注意力模型】 三、Transformer图文详解【Attention is all you need】 四、大语言模型的Scaling Law【Power Low】 文章目录 NLP-大语言模型学习系列目录一、什么是…

隧道煤矿甬道的可视化大屏,关键时刻起关键作用

隧道、煤矿甬道的可视化大屏在关键时刻确实能发挥关键作用。它可以实时显示内部的环境参数&#xff0c;如温度、湿度、瓦斯浓度等&#xff0c;帮助工作人员及时掌握潜在危险情况。 同时&#xff0c;大屏能展示人员分布和设备运行状态&#xff0c;便于高效调度和管理。 在紧急…

计算机网络:网络层 —— IPv4 地址与 MAC 地址 | ARP 协议

文章目录 IPv4地址与MAC地址的封装位置IPv4地址与MAC地址的关系地址解析协议ARP工作原理ARP高速缓存表 IPv4地址与MAC地址的封装位置 在数据传输过程中&#xff0c;每一层都会添加自己的头部信息&#xff0c;最终形成完整的数据包。具体来说&#xff1a; 应用层生成的应用程序…

技术成神之路:设计模式(二十一)外观模式

相关文章&#xff1a;技术成神之路&#xff1a;二十三种设计模式(导航页) 介绍 外观模式&#xff08;Facade Pattern&#xff09;是一种结构型设计模式&#xff0c;它为子系统中的一组接口提供一个统一的接口。外观模式定义了一个高层接口&#xff0c;使得子系统更容易使用。 …

qt QGraphicsGridLayout详解

一、概述 QGraphicsGridLayout是Qt框架中用于在QGraphicsScene中布置图形项的一个布局管理器。它类似于QWidget中的QGridLayout&#xff0c;但主要处理的是QGraphicsItem和QGraphicsWidget等图形项。通过合理设置网格位置、伸缩因子和尺寸&#xff0c;可以实现复杂而灵活的布局…

【论文笔记】MLSLT: Towards Multilingual Sign Language Translation

&#x1f34e;个人主页&#xff1a;小嗷犬的个人主页 &#x1f34a;个人网站&#xff1a;小嗷犬的技术小站 &#x1f96d;个人信条&#xff1a;为天地立心&#xff0c;为生民立命&#xff0c;为往圣继绝学&#xff0c;为万世开太平。 基本信息 标题: MLSLT: Towards Multiling…

2024-网鼎杯第二次模拟练习-web02

进入做题页面&#xff0c;经过信息搜集和目录扫描&#xff0c;发现只有一个公告是可以利用的 http://0192c74e0f9871c2956795c804c3dde3.8nfp.dg01.wangdingcup.com:43014/OA_announcement.php?id1 这个后面有一个明显的注入点&#xff0c;经过多次刷新和快速刷新后发现&…

使用FRP搭建内网穿透服务(新版toml配置文件,搭配反向代理方便内网网站访问)【使用frp搭建内网穿透】

FRP&#xff08;Fast Reverse Proxy&#xff09;是一个高性能的反向代理应用程序&#xff0c;主要用于内网穿透。它允许用户将内部网络服务暴露到外部网络&#xff0c;适用于 NAT 或防火墙环境下的服务访问。 他是一个开源的 服务 如果大家不想用 花生壳 软件&#xff0c;可以尝…

基于信号分解和多种深度学习结合的上证指数预测模型

大家好&#xff0c;我是带我去滑雪&#xff01; 为了给投资者提供更准确的投资建议、帮助政府和监管部门更好地制定相关政策&#xff0c;维护市场稳定&#xff0c;本文对股民情绪和上证指数之间的关系进行更深入的研究&#xff0c;并结合信号分解、优化算法和深度学习对上证指数…

探索孤独症儿童治愈的希望之路

孤独症&#xff0c;作为一种严重影响儿童发展的神经发育障碍性疾病&#xff0c;给无数家庭带来了难以承受的沉重负担。然而&#xff0c;人们始终未曾放弃对孤独症儿童治愈可能性的不懈探索。 早期干预乃是关键所在。一旦儿童被诊断为孤独症&#xff0c;就应迅速启动全面且系统的…

分类预测 | GCN图卷积神经网络多特征分类预测(MATLAB)

分类预测 | GCN图卷积神经网络多特征分类预测(MATLAB) 目录 分类预测 | GCN图卷积神经网络多特征分类预测(MATLAB)分类效果基本介绍程序设计参考资料分类效果 基本介绍 GCN图卷积神经网络多特征分类预测(MATLAB) 在图卷积神经网络(GCN)中,多特征分类

orange pi开启vnc服务,并使用mac远程连接

先输入vncserver看一下是否开启了vnc服务&#xff0c;如果提示输入密码&#xff0c;就是正在开启&#xff0c;然后选择只是查看权限还是也有控制权限&#xff0c;肯定要控制阿&#xff0c;所以选择n。 或者输入&#xff1a;sudo netstat -pl | grep vnc 如果能找到vnc的进程&a…

ThriveX 现代化博客管理系统

ThriveX 现代化博客管理系统 &#x1f389; &#x1f525; 首先最重要的事情放第一 开源不易&#xff0c;麻烦占用 10 秒钟的时间帮忙点个免费的 Star&#xff0c;再此万分感谢&#xff01; 下面开始进入主题↓↓↓ &#x1f308; 项目介绍&#xff1a; Thrive 是一个简而不…

生活中是否害怕过机械硬盘出现坏道?

目录 一、坏道起因 二、继续了解-系统对坏扇区的处理 &#xff08;一&#xff09;硬盘自身的处理机制 &#xff08;二&#xff09;操作系统层面的处理 三、进一步了解-备用扇区 &#xff08;一&#xff09;备用扇区的工作原理 &#xff08;二&#xff09;S.M.A.R.T.技术…

DMVPN协议

DMVPN&#xff08;Dynamic Multipoint VPN&#xff09;动态多点VPN 对于分公司和分总公司内网实现通信环境下&#xff0c;分公司是很多的。我们不可能每个分公司和总公司都挨个建立ipsec隧道 &#xff0c;而且如果是分公司和分公司建立隧道&#xff0c;就会很麻烦。此时我们需…