P1 练习卷(C++4道题)

1.纷繁世界

内存限制:256MB 时间限制:1s

问题描述

  这是一个纷繁复杂的世界。 某一天清晨你起床很迟,没有吃上早饭。于是你骑着自行车去超市,但是你又发现商店的工作人员已经重新贴上了价格标签,零食价格都涨了50%。你一怒之下就这样饿了一个上午…… 当然,事情也许完全不会这样发展。 某一天清晨你起床比较迟,但还是没有吃上早饭。于是你骑着自行车去超市,恰好商店的工作人员还没有把涨价后的价格标签贴在零食上。于是你顺利的买了一些早餐然后逍遥而去…… 或许你会起得更早,也或许商店的工作人员会迟到。 有时候,人们只是按照预想的顺序去完成一些事情,不过可能有一些事件,它们发生时间的前后顺序会影响世界的发展。 比如,如果商店只有一个西瓜,你想买,我也想买,那么我们买西瓜的先后顺序就会直接影响到谁最后能够买到西瓜。 这样一个复杂的世界,分析它的运行规律是一件非常重要的工作,也是你所要研究的。

问题描述

  简单起见,假定总共有N个人以及M种不同类型事件。 定义事件之间的二元关系“相关”:
  . 相关关系是一个二元关系,就是说我们只能定义两种类型的事件间是否相关;
  . 同一种类型的事件之间一定是相关的;
  . 若事件x与事件y是相关的,那么事件y与事件x也一定是相关的;
  令表示第i个人计划完成的事件序列(称为计划序列),Ci表示Qi的长度。Qi中每个事件Qi,j都是M种事件中的某一种,且同一种类型的事件可以发生多次。 随着时间的推移每个计划序列中的事件都会发生一次且恰好一次;为了简单起见,不会有任何两个事件发生在同一时刻。
  为了描述事件的发生顺序,定义为世界的一条发展轨迹,P是满足如下条件的有序序列:
  1. 对于每个人,计划序列中的每个事件Qi,j都在P出现一次且恰好一次;
  2. 对于属于同一个计划序列的两个事件Qi,j1和Qi,j2(1 ≤ j1 < j2 ≤ Ci),Qi,j1一定发生在Qi,j2之前(也就是在P中位于更靠前的位置);
  两条轨迹P1和P2被定义为本质不同的,当且仅当存在两个相关的事件Qi,j和Qu,v,他们在P1和P2中发生的先后顺序不同,也就是说,如果在P1中Qi,j发生在Qu,v之前且在P2中Qi,j发生在Qu,v之后,那么P1和P2就是本质不同的;如果在P1中Qi,j发生在Qu,v之后且在P2中Qi,j发生在Qu,v之前,那么P1和P2也是本质不同的; 注意:本质相同具有传递性,即若P1与P2本质相同且P2与P3本质相同,那么P1与P3一定也本质相同。
  给定N, M、每个人计划序列以及事件之间的相关关系。你需要计算一共有多少种本质不同的世界运行轨迹。

输入格式

  输入文件world.in第一行包括一个整数,表示人数N。 输入文件第二行包括一个整数,表示事件种类数M,所有类型的事件按照0至M – 1编号。 接下来依次给出每个人的计划序列的描述,对于第i个人: 首先一行一个整数表示序列长度Ci。 第二行包含Ci个整数,依次给出Qi中的每个事件Qi,j。 最后M行输入一个M行M列的矩阵dep用来描述相关关系,每行包含M个整数,都是0或者1。dep(i,j)表示矩阵自上往下的第i行,自左往右的第j列所包含的整数。若dep(i, j)的值为1,那么第i类事件和第j类事件就是相关的,否则这两类事件不相关。

输出格式

  输出文件world.out只有一行,一个整数表示本质不同的世界轨迹数T。

样例输入   

2
3
2
0
1
2
2
1
1 1 0
1 1 1
0 1 1

样例输出   

4

样例说明

  样例中有2个人与3类事件,C1 = C2 = 2。Q1,0 = 0, Q1,1 = 1, Q2,0 = 2, Q2,1 = 1。
  一共有4种不同的发生轨迹:
  P1 = (Q1,0, Q1,1, Q2,0, Q2,1)
  P2 = (Q1,0, Q2,0, Q1,1, Q2,1)
  P3 = (Q1,0, Q2,0, Q2,1, Q1,1)
  P4 = (Q2,0, Q2,1, Q1,0, Q1,1)
  对于其他任何合法的发展轨迹,都一定和这四条轨迹中的某一条本质相同。例如P = (Q2,0, Q1,0, Q2,1, Q1,1)与P3是本质相同的,因为两条轨迹只交换了Q1,0 = 0和Q2,0 = 2的顺序,但是这两类事件是不相关的。

数据规模和约定

  总人数N ≤ 10;
  事件种类数 M ≤ 15;
  计划序列长度Ci ≤ 20;
  世界轨迹数T ≤ 106。

2.道路游戏

时间限制:1s 内存限制:128MB

小新正在玩一个简单的电脑游戏。

游戏中有一条环形马路,马路上有 n 个机器人工厂,两个相邻机器人工厂之间由一小段马路连接。小新以某个机器人工厂为起点,按顺时针顺序依次将这 n个机器人工厂编号为 1∼n,因为马路是环形的,所以第 n个机器人工厂和第 1个机器人工厂是由一段马路连接在一起的。小新将连接机器人工厂的这 n 段马路也编号为 1∼n,并规定第 i 段马路连接第 i 个机器人工厂和第 i+1个机器人工厂(1≤i≤n−1),第 n 段马路连接第 n 个机器人工厂和第 1 个机器人工厂。

游戏过程中,每个单位时间内,每段马路上都会出现一些金币,金币的数量会随着时间发生变化,即不同单位时间内同一段马路上出现的金币数量可能是不同的。小新需要机器人的帮助才能收集到马路上的金币。所需的机器人必须在机器人工厂用一些金币来购买,机器人一旦被购买,便会沿着环形马路按顺时针方向一直行走,在每个单位时间内行走一次,即从当前所在的机器人工厂到达相邻的下一个机器人工厂,并将经过的马路上的所有金币收集给小新,例如,小新在 ii(1≤i≤n)号机器人工厂购买了一个机器人,这个机器人会从 ii 号机器人工厂开始,顺时针在马路上行走,第一次行走会经过 i 号马路,到达 i+1 号机器人工厂(如果 i=n,机器人会到达第 1 个机器人工厂),并将 i 号马路上的所有金币收集给小新。游戏中,环形马路上不能同时存在 2 个或者 2 个以上的机器人,并且每个机器人最多能够在环形马路上行走 p 次。小新购买机器人的同时,需要给这个机器人设定行走次数,行走次数可以为 1∼p 之间的任意整数。当马路上的机器人行走完规定的次数之后会自动消失,小新必须立刻在任意一个机器人工厂中购买一个新的机器人,并给新的机器人设定新的行走次数。

以下是游戏的一些补充说明:

  1. 游戏从小新第一次购买机器人开始计时。
  2. 购买机器人和设定机器人的行走次数是瞬间完成的,不需要花费时间。
  3. 购买机器人和机器人行走是两个独立的过程,机器人行走时不能购买机器人,购买完机器人并且设定机器人行走次数之后机器人才能行走。
  4. 在同一个机器人工厂购买机器人的花费是相同的,但是在不同机器人工厂购买机器人的花费不一定相同。
  5. 购买机器人花费的金币,在游戏结束时再从小新收集的金币中扣除,所以在游戏过程中小新不用担心因金币不足,无法购买机器人而导致游戏无法进行。也因为如此,游戏结束后,收集的金币数量可能为负。

现在已知每段马路上每个单位时间内出现的金币数量和在每个机器人工厂购买机器人需要的花费,请你告诉小新,经过 m 个单位时间后,扣除购买机器人的花费,小新最多能收集到多少金币。

输入格式

第一行 3 个正整数 n,m,p,意义如题目所述。

接下来的 nn 行,每行有 mm 个正整数,每两个整数之间用一个空格隔开,其中第 ii 行描述了 ii 号马路上每个单位时间内出现的金币数量(1≤金币数量 ≤100),即第 i 行的第 j(1≤j≤m)个数表示第 j 个单位时间内 i 号马路上出现的金币数量。

最后一行,有 n 个整数,每两个整数之间用一个空格隔开,其中第 i 个数表示在 i号机器人工厂购买机器人需要花费的金币数量(1≤金币数量 ≤100)。

输出格式

共一行,包含 11 个整数,表示在 mm 个单位时间内,扣除购买机器人花费的金币之后,小新最多能收集到多少金币。

输入输出样例

输入 #1

2 3 2 
1 2 3 
2 3 4 
1 2

输出 #1

5

说明/提示

对于 40% 的数据,2≤n≤40,1≤m≤40。

对于 90% 的数据,2≤n≤200,1≤m≤200。

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

NOIP 2009 普及组 第四题

3.查词典

时间限制:1s 内存限制:128MB

题目描述:

小A有一本词典,一天他在写英语老师留的阅读理解题中,遇到了n不会的词。

小A很贪玩,想要在t分钟后写完阅读理解的作业,然后就可以去玩手机去了。

但是他查词典的速度很慢,如果把他不会的单词全都查一遍,那肯定会超过t分钟

所以他快速浏览了一遍单词,发现他不会的单词中,有一部分很重要,还有一部分即使不会也不影响文章整体阅读,所以他列了一个清单,给每个单词做了一个重要度和查该单词所需的时间

现在小A想知道,在t分钟之内(不一定非要花光t分钟,可以提前结束 ),自己能查到的所有单词的重要度总和最大是多少。

输入格式

第一行两个整数 n,t

接下来n行,每行两个整数:time[i],important[i]

输出格式

一个整数,表示小A能查到的单词的重要度总和的最大值

输入样例

5 10

1 1

2 2

3 3

4 4

5 10

输出样例

15

数据规模

0<n,t<=10^12

提示

本题数据很大,需要开long long

4. 朋友圈(强化版)

时间限制 0.5s 内存限制 100MB

题目描述

在很久很久以前,曾经有两个国家和睦相处,无忧无虑的生活着.

一年一度的评比大会开始了,作为和平的两国,一个朋友圈数量最多的永远都是最值得他人的尊敬,所以现在就是需要你求朋友圈的最大数目.两个国家看成是 AB 两国,现在是两个国家的描述:

  • A 国:每个人都有一个友善值,当两个 A 国人的友善值 a,ba,b,如果 (axorb) mod 2=1(axorb)mod2=1,那么这两个人都是朋友,否则不是;
  • B 国:每个人都有一个友善值,当两个 B 国人的友善值 a,ba,b,如果 (axorb) mod 2=0(axorb)mod2=0 或者 (aorb)(aorb) 化成二进制有奇数个 11,那么两个人是朋友,否则不是朋友.

A、B 两国之间的人也有可能是朋友,数据中将会给出 A、B 之间「朋友」的情况.

对于朋友的定义,关系是是双向的.

在 AB 两国,朋友圈的定义:一个朋友圈集合 SS,满足 S⊂A∪BS⊂A∪B,对于所有的 i,j∈Si,j∈S,ii 和 jj 是朋友.

输入格式

本题包含多组数据.

  • 第一行一个整数 TT,表示输入数据总数.
  • 对于每组数据:
    • 第 11 行 33 个整数 A,B,MA,B,M,分别表示 A 国人数,B 国人数,AB 两国之间是朋友的对数.
    • 第 22 行 AA 个整数 aiai​,表示 A 国第 ii 个人的友善值.
    • 第 33 行 BB 个整数 bibi​,表示 B 国第 ii 个人的友善值.
    • 第 44 到第 3+M3+M 行,每行两个整数 x,yx,y 表示 A 国的第 xx 个人和 B 国第 yy 个人是朋友.

输出格式

  • 输出 TT 行,每行输出一个整数,表示最大朋友圈的数目.

输入输出样例

输入 #1

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

输出 #1

5

说明/提示

样例解释

最大朋友圈包含 A 国第 1,2人和 B 国第 1,2,3人.

数据范围

对于 100% 的数据,1≤T≤6,1≤ai,bi<231

本题共有两类数据,保证所有测试点均满足其中至少一类的限制:

  • 第一类:1≤A≤20000,1≤B≤20000
  • 第二类:1≤A≤15,1≤B≤30000

评分:

0-20:

编程水平较弱,CSP-J复赛大约可得50-120分, 不建议报考CSP-S

20-100:

编程水平一般,CSP-J复赛大约可得三等奖-二等奖,建议尝试报考CSP-S

100-200:

编程水平较强,建议报考CSP-S,S组复赛大约可得80分

200-300:

编程水平强,建议报考NOI

300-350:

编程水平很强,和开挂一样,建议报考NOI

350-400

666,这个入是挂

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

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

相关文章

Selenium的八种定位方式

1. 通过 ID 定位 ID 是最直接和高效的方式来定位元素&#xff0c;因为每个页面中的 ID 应该是唯一的。 from selenium import webdriverdriver webdriver.Chrome(executable_pathpath/to/chromedriver) driver.get(https://example.com)# 通过 ID 定位 element driver.find…

logback动态获取nacos配置

文章目录 前言一、整体思路二、使用bootstrap.yml三、增加环境变量四、pom文件五、logback-spring.xml更改总结 前言 主要是logback动态获取nacos的配置信息,结尾完整代码 项目springcloudnacosplumelog&#xff0c;使用的时候、特别是部署的时候&#xff0c;需要改环境&#…

OpenMM的安装与使用

技术背景 OpenMM是一款基于Python开发的开源分子动力学模拟软件&#xff0c;这几年因为AlphaFold的缘故&#xff0c;使得这个软件的热度有了不少提升。并且可以使用GPU硬件加速&#xff0c;所以性能上也不赖。这里介绍一下该软件的基本安装和使用方法&#xff0c;并附带一个真空…

Linux各种并发服务器优缺点

本文旨在介绍针对“无并发C/S模型”改进的方法总结以及各种改进方法的优缺点&#xff0c;具体函数的实现并不介绍。 1. 无并发C/S模型 创建服务器流程分析&#xff1a; socket()创建服务器的监听套接字bind()将服务器给服务器的监听套接字绑定IP地址和Port端口号listen()设置…

cookie反爬----普通服务器,阿里系

目录 一.常见COOKIE反爬 普通&#xff1a; 1. 简介 2. 加密原理 二.实战案例 1. 服务器响应cookie信息 1. 逆向目标 2. 逆向分析 2. 阿里系cookie逆向 1. 逆向目标 2. 逆向分析 实战&#xff1a; 无限debugger原理 1. Function("debugger").call() 2. …

网络无人值守批量装机-cobbler

网络无人值守批量装机-cobbler 一、cobbler简介 ​ 上一节中的pxe+kickstart已经可以解决网络批量装机的问题了,但是环境配置过于复杂,而且仅针对某一个版本的操作系统进批量安装则无法满足目前复杂环境的部署需求。 ​ 本小节所讲的cobbler则是基于pxe+kickstart技术的二…

推荐一款开源电子书阅读器Koodo Reader

Koodo Reader 是一个开源的电子书阅读器&#xff0c;支持多达15种主流电子书格式&#xff0c; 内置笔记、高亮、翻译功能&#xff0c;助力高效书籍阅读和学习。 官网地址&#xff1a;https://www.koodoreader.com/zh 一、下载软件 下载地址&#xff1a;https://dl.koodoreader.…

FreeRTOS——互斥信号量

一、为什么需要互斥信号量 前面的学习中&#xff1a; 调度锁、临界段不可避免的破坏了实时性&#xff0c;还有二值信号量存在这样的隐患——“优先级翻转” 优先级翻转 简单来说&#xff0c;就是由于信号量被低优先级任务占用&#xff0c;即使遇到高优先级任务&#xff0c;它…

AIGC学习笔记(6)——AI大模型开发工程师

文章目录 AI大模型开发工程师005 OpenAI大模型案例实践1 AI 翻译助手需求分析项目起源市场价格和市场前景基于大模型的翻译软件核心功能设计 2 AI 翻译助手架构设计架构设计代码结构设计 3 AI 翻译助手核心功能文档解析文档操作PDF文档操作表格操作图片操作 Prompt封装 4 AI 翻…

程序语言语法上手题目合集

程序语言语法上手题目合集 1跑步2猜年龄3Vigenre 密码 1跑步 2.跑步 - 蓝桥云课 枚举日期&#xff0c;判断是否符合条件即可。 参考程序&#xff1a; #include<stdio.h> int y2022,m1,d1; int week6; int month[13]{0,31,28,31,30,31,30,31,31,30,31,30,31};int judg…

C#调用C++ DLL方法之P/Invoke

关于P/Invoke Platform Invoke (P/Invoke) 是 .NET 提供的一种服务&#xff0c;允许托管代码&#xff08;如 C#&#xff09;调用非托管代码&#xff08;如 C/C 编写的 DLL 函数&#xff09;。通过 P/Invoke&#xff0c;可以在 .NET 应用程序中使用现有的非托管代码库&#xff…

Centos Stream 9安装Jenkins-2.485 构建自动化项目步骤

官网&#xff1a;https://www.jenkins.io/ 1 下载 环境准备&#xff1a; 版本支持查询&#xff1a;https://pkg.jenkins.io/redhat-stable/ 安装JDK17&#xff1a;https://blog.csdn.net/qq_44870331/article/details/140784297 yum -y install epel-release wget upgradew…

青训营刷题笔记16

问题描述 小R从班级中抽取了一些同学&#xff0c;每位同学都会给出一个数字。已知在这些数字中&#xff0c;某个数字的出现次数超过了数字总数的一半。现在需要你帮助小R找到这个数字。 测试样例 样例1&#xff1a; 输入&#xff1a;array [1, 3, 8, 2, 3, 1, 3, 3, 3] 输出…

Go语言链接Redis数据库

1.使用go get命令安装go-redis/v8库&#xff1a; 我这里使用的vscode工具安装&#xff1a; go get github.com/go-redis/redis/v82.创建Redis客户端实例 使用以下Go代码连接到Redis服务器并执行命令&#xff1a; package mainimport ("context""fmt"&q…

Mybatis 核心配置文件

MyBatis的全局配置文件mybatis-config.xml&#xff0c;配置内容如下&#xff1a; properties&#xff08;属性&#xff09; settings&#xff08;全局配置参数&#xff09; typeAliases&#xff08;类型别名&#xff09; typeHandlers&#xff08;类型处理器&#xff09; obj…

09 —— Webpack搭建开发环境

搭建开发环境 —— 使用webpack-dev-server 启动Web服务&#xff0c;自动检测代码变化&#xff0c;有变化后会自动重新打包&#xff0c;热更新到网页&#xff08;代码变化后&#xff0c;直接替换变化的代码&#xff0c;自动更新网页&#xff0c;不用手动刷新网页&#xff09; …

TCP vs UDP:如何选择适合的网络传输协议?

在网络通信中&#xff0c;TCP&#xff08;Transmission Control Protocol&#xff09;和UDP&#xff08;User Datagram Protocol&#xff09;是两种非常重要的传输层协议。它们各有特点&#xff0c;适用于不同类型的应用场景。本文将详细探讨TCP和UDP协议的结构、优缺点及应用&…

网络安全之内网安全

下面给出了应对企业内网安全挑战的10种策略。这10种策略即是内网的防御策略&#xff0c;同时也是一个提高大型企业网络安全的策略。 1、注意内网安全与网络边界安全的不同 内网安全的威胁不同于网络边界的威胁。网络边界安全技术防范来自Internet上的攻击&#xff0c;主要是防…

7-2 扑克牌花色

作者 李祥 单位 湖北经济学院 给 52 张扑克牌面编号如下&#xff1a; 编号牌面编号牌面编号牌面编号牌面0♠A13♥A26♣A39♦A1♠214♥227♣240♦22♠315♥328♣341♦33♠416♥429♣442♦44♠517♥530♣543♦55♠618♥631♣644♦66♠719♥732♣745♦77♠820♥833♣846♦88♠9…

windows 中docker desktop 安装

前提条件&#xff1a; 安装wsl2 1. 下载 Docker Desktop 访问 Docker Desktop 官方下载页面。 https://www.docker.com/products/docker-desktop/ 根据你的操作系统架构&#xff08;一般为 Windows x86_64&#xff09;下载安装程序。 选择标准&#xff1a; AMD64 是行业…