CSP-J第二轮试题-2019年-1、2题
文章目录
- 参考:
- 总结
- [CSP-J2019] 数字游戏
- 题目描述
- 输入格式
- 输出格式
- 样例 #1
- 样例输入 #1
- 样例输出 #1
- 样例 #2
- 样例输入 #2
- 样例输出 #2
- 提示
- 答案
- 答案2
- [CSP-J 2019] 公交换乘
- 题目描述
- 输入格式
- 输出格式
- 样例 #1
- 样例输入 #1
- 样例输出 #1
- 样例 #2
- 样例输入 #2
- 样例输出 #2
- 提示
- 答案1
- 答案2
- 现场真题注意事项

参考:
https://www.luogu.com.cn/problem/P5660
https://www.luogu.com.cn/problem/P5661
总结
本系列为CSP-J/S算法竞赛真题讲解,会按照年份分析每年的真题,并给出对应的答案。本文为2019年真题。
https://www.luogu.com.cn/problem/list?tag=343&page=1
[CSP-J2019] 数字游戏
题目描述
小 K 同学向小 P 同学发送了一个长度为 8 8 8 的 01 字符串来玩数字游戏,小 P 同学想要知道字符串中究竟有多少个 1 1 1。
注意:01 字符串为每一个字符是 0 0 0 或者 1 1 1 的字符串,如“101”(不含双引号)为一个长度为 3 3 3 的 01 字符串。
输入格式
输入文件只有一行,一个长度为 8 8 8 的 01 字符串 s s s。
输出格式
输出文件只有一行,包含一个整数,即 01 字符串中字符 1 \bm 1 1 的个数。
样例 #1
样例输入 #1
00010100
样例输出 #1
2
样例 #2
样例输入 #2
11111111
样例输出 #2
8
提示
【输入输出样例 1 说明】
该 01 字符串中有 2 2 2 个字符 1 1 1。
【输入输出样例 2 说明】
该 01 字符串中有 8 8 8 个字符 1 1 1。
【数据规模与约定】
- 对于 20 % 20\% 20% 的数据,保证输入的字符全部为 0 0 0。
- 对于 100 % 100\% 100% 的数据,输入只可能包含字符 0 0 0 和字符 1 1 1,字符串长度固定为 8 8 8。
答案
//#include <bits/stdc++.h>
#include<cstdio>//必须包含cstdio头文件
using namespace std;int main(){//freopen("candy.in","r",stdin);//freopen("candy.out","w",stdout);char x;int ans=0;for(int i=1;i<=8;i++){scanf("%c",&x);if(x=='1')ans++;}printf("%d\n",ans);return 0;
}
输出:

答案2
#include<iostream>
using namespace std;
int ans=0;//ans计数器
char s[21];//字符串开大一点
int main(){cin>>s;for(int i=0;i<8;i++){//模拟if(s[i]=='1'){//判断是否为1ans++;//计数器++}}cout<<ans<<endl;return 0;//完美结束
}
输出为:

[CSP-J 2019] 公交换乘
题目描述
著名旅游城市 B 市为了鼓励大家采用公共交通方式出行,推出了一种地铁换乘公交车的优惠方案:
- 在搭乘一次地铁后可以获得一张优惠票,有效期为 45 分钟,在有效期内可以消耗这张优惠票,免费搭乘一次票价不超过地铁票价的公交车。在有效期内指开始乘公交车的时间与开始乘地铁的时间之差小于等于 45 分钟,即:
t b u s − t s u b w a y ≤ 45 t_{bus} - t_{subway} \leq 45 tbus−tsubway≤45 - 搭乘地铁获得的优惠票可以累积,即可以连续搭乘若干次地铁后再连续使用优惠票搭乘公交车。
- 搭乘公交车时,如果可以使用优惠票一定会使用优惠票;如果有多张优惠票满足条件,则优先消耗获得最早的优惠票。
现在你得到了小轩最近的公共交通出行记录,你能帮他算算他的花费吗?
输入格式
输入文件的第一行包含一个正整数 n n n,代表乘车记录的数量。
接下来的 n n n 行,每行包含 3 个整数,相邻两数之间以一个空格分隔。第 i i i 行的第 1 个整数代表第 i i i 条记录乘坐的交通工具,0 代表地铁,1 代表公交车;第 2 个整数代表第 i i i 条记录乘车的票价 p r i c e i price_i pricei ;第三个整数代表第 i i i 条记录开始乘车的时间 t i t_i ti(距 0 时刻的分钟数)。
我们保证出行记录是按照开始乘车的时间顺序给出的,且不会有两次乘车记录出现在同一分钟。
输出格式
输出文件有一行,包含一个正整数,代表小轩出行的总花费。
样例 #1
样例输入 #1
6
0 10 3
1 5 46
0 12 50
1 3 96
0 5 110
1 6 135
样例输出 #1
36
样例 #2
样例输入 #2
6
0 5 1
0 20 16
0 7 23
1 18 31
1 4 38
1 7 68
样例输出 #2
32
提示
【输入输出样例 1 说明】
第一条记录,在第 3 分钟花费 10 元乘坐地铁。
第二条记录,在第 46 分钟乘坐公交车,可以使用第一条记录中乘坐地铁获得的优惠票,因此没有花费。
第三条记录,在第 50 分钟花费 12 元乘坐地铁。
第四条记录,在第 96 分钟乘坐公交车,由于距离第三条记录中乘坐地铁已超过 45 分钟,所以优惠票已失效,花费 3 元乘坐公交车。
第五条记录,在第 110 分钟花费 5 元乘坐地铁。
第六条记录,在第 135 分钟乘坐公交车,由于此时手中只有第五条记录中乘坐地铁获得的优惠票有效,而本次公交车的票价为 6 元,高于第五条记录中地铁的票价 5 元,所以不能使用优惠票,花费 6 元乘坐公交车。
总共花费 36 元。
【输入输出样例 2 说明】
第一条记录,在第 1 分钟花费 5 元乘坐地铁。
第二条记录,在第 16 分钟花费 20 元乘坐地铁。
第三条记录,在第 23 分钟花费 7 元乘坐地铁。
第四条记录,在第 31 分钟乘坐公交车,此时只有第二条记录中乘坐的地铁票价高于本次公交车票价,所以使用第二条记录中乘坐地铁获得的优惠票。
第五条记录,在第 38 分钟乘坐公交车,此时第一条和第三条记录中乘坐地铁获得的优惠票都可以使用,使用获得最早的优惠票,即第一条记录中乘坐地铁获得的优惠票。
第六条记录,在第 68 分钟乘坐公交车,使用第三条记录中乘坐地铁获得的优惠票。
总共花费 32 元。
【数据规模与约定】
对于 30 % 30\% 30% 的数据, n ≤ 1000 n \leq 1000 n≤1000, t i ≤ 1 0 6 t_i \leq 10^6 ti≤106。
另有 15 % 15\% 15% 的数据, t i ≤ 1 0 7 t_i \leq 10^7 ti≤107, p r i c e i price_i pricei 都相等。
另有 15 % 15\% 15% 的数据, t i ≤ 1 0 9 t_i \leq 10^9 ti≤109, p r i c e i price_i pricei 都相等。
对于 100 % 100\% 100% 的数据, n ≤ 1 0 5 n \leq 10^5 n≤105, t i ≤ 1 0 9 t_i \leq 10^9 ti≤109, 1 ≤ p r i c e i ≤ 1000 1 \leq price_i \leq 1000 1≤pricei≤1000。
答案1
#include<bits/stdc++.h>
using namespace std;//乘车记录的数量(n)
int n;
// 交通工具(g)、票价(p)、时间(t)
int g[100010],p[100010],t[100010];
int sum=0;//总花费(sum)
int ques=0; //优惠票总数(ques)queue<int> q1;//优惠票时间队列(q1)
queue<int> q2;//优惠票价钱队列(q1)int main()
{cin>>n;// 记录条数nfor(int i=1; i<=n; i++){// 记录交通工具(g)、票价(p)、时间(t)cin>>g[i]>>p[i]>>t[i];// 判断地铁if (g[i] ==0){//因为地铁一定要花钱,所以将总花费(sum)加上票价(p)//坐地铁一定会拿到一张优惠票,//我们将优惠票的时间压入时间队列(q1),//将票价压入价钱队列(q2),并将优惠票的数量(ques)加1sum += p[i];q1.push(t[i]);q2.push(p[i]);ques++;}// 筛出废票//当优惠票超过45分后,该优惠票就会失效,//因为队列FIFO的特性,只要队首的那张没超时,就代表后面的都没超时。//因此使用while循环(附加非空判定以防万一)while(t[i]-q1.front()>45 && !q1.empty()){//只要循环进去了,说明这张票废了,// 把两个队列(q1q2)的队首都弹出,并把优惠票数量(ques)减1q1.pop();q2.pop();ques--;}int f=0;//优惠票使用状态int quesd = ques;//优惠票备用数量quesd//判断公交if(g[i]==1){//接下来为保险起见分为有优惠票(优惠票队列(q1q2)非空)和//无优惠票(优惠票队列(q1q2)为空)两种情况考虑。先写出判断语句if(!q1.empty()){/*接下来进入重头戏,就是当有优惠票时,因为优惠票可能会不能用,而且没有规律(不像时间队列(q1)有规律),在这里所有的优惠票肯定都不会超时(超时的全弹出去了)。我们在这里使用这样的方法:把队列(q1q2)从头到尾检索一次,即使已经有符合的了也要全检索完(因为优惠票需要按时间顺序排列,其顺序不能更改)。如何检索呢?只需要把队首压入队尾,再把队首弹出就可以了,这样第一位就会变到最后一位,第二位变到第一位,以此类推。当全部走完后,第一位又会变回第一位。*///首先,进行循环/*为什么这里要用备用数量(quesd)呢?因为假设有优惠票被使用,那么此票就会被弹出,数量(ques)会减1(参见上文第四大步),因为数量会变,所以需要存一个固定的值,也就是quesd紧接着分两种情况,一种是该票可以使用,一种是该票不能使用。可以使用即是价钱队列(q2)的队首大于等于乘坐此次公交所花的钱,不可以使用则反之。为判断方便,以可以使用为条件,不可以使用为该条判断的else*/if(f ==0 && p[i]<=q2.front()){/*此处的使用状态(f)为后期进行判定时使用,f为0表示本轮还没有使用优惠票,f为1表示本轮使用了优惠票当满足条件时,表示可以使用优惠票,f的值改为1,并将该票弹出队列(q1q2),优惠票数量(ques)减1*/f=1;q1.pop();q2.pop();ques--;}else{q1.push(q1.front());q2.push(q2.front());q1.pop();q2.pop();}}else{//当无优惠票时,无论如何都要花钱,//else里面将总花费(sum)加上票价(p)。sum += p[i];continue;}if ( f == 0 ){sum += p[i] ;}}}cout<<sum;return 0;//完美结束
}
输出为:

答案2
#include <iostream>using namespace std;
const int MAXN = 100005;
struct Ticket {//赠票的价格,最晚使用时间和是否需用过int price, time, used;
} q[MAXN];//赠票盒子
int head, tail, n, cost;int main() {cin >> n;for (int i = 0; i < n; ++i) {int op, price, time;//输入每次坐车的种类,价格和发车时间cin >> op >> price >> time;if (op == 0) {//如果是坐地铁,直接把价格加到cost里面cost += price;//新一张赠票插入数组末尾,这张票的最晚使用时间是当前时间+45q[tail].time = time + 45;//赠票面额就是地铁票价q[tail++].price = price;} else {//先用一个循环把过期票扔掉while (head < tail && q[head].time < time) {head++;}bool found = false;//表示是否有合适的赠票,先假设没有for (int j = head; j < tail; ++j) {//循环所有剩余的票,这些一定都没过期,因为题目中时间是按顺序给我们的if (q[j].price >= price && q[j].used == 0) {//如果价格合适,并且没用过,标记找到了,这张票标记用过found = true;q[j].used = 1;break;}}//如果没找到合适的赠票,老老实实花钱买吧if (!found) cost += price;}}cout << cost << endl;return 0;
}
输出为:

现场真题注意事项
https://cspoj.com/contest.php?cid=1002
Fus5yz4x3EcSJH1Z
注意事项
- 文件名(程序名和输入输出文件名)必须使用英文小写。(提交必须使用freopen()进行提交)
- C/C++ 中函数 main() 的返回值类型必须是 int,程序正常结束时的返回值必须是0。
- 提交的程序代码文件的放置位置请参考各省的具体要求。
- 因违反以上三点而出现的错误或问题,申述时一律不予受理。
- 若无特殊说明,结果的比较方式为全文比较(过滤行末空格及文末回车)。
- 程序可使用的栈空间内存限制与题目的内存限制一致。
- 全国统一评测时采用的机器配置为:Inter® Core™ i7-8700K CPU @3.70GHz,内存 32GB。上述时限以此配置为准。
- 只提供 Linux 格式附加样例文件。
- 评测在当前最新公布的 NOI Linux 下进行,各语言的编译器版本以此为准
/*
假设输入样例数据存在文件test.in中,输出样例数据存在文件test.out中,
则在CSP、NOI等比赛的代码中,需添加freopen、fclose语句,
内容详见模板代码如下。
*/
#include <bits/stdc++.h>
#include<cstdio>//必须包含cstdio头文件
#include<iostream>
using namespace std;int main(){freopen("test.in","r",stdin);freopen("test.out","w",stdout);cout<<"Hello NOI"<<endl;fclose(stdin);fclose(stdout);return 0;
}
下面为函数的简介,详细可参见 http://www.cplusplus.com/reference/clibrary/cstdio/freopen.html
函数名:freopen
声明:FILE *freopen( const char *path, const char *mode, FILE *stream );
所在文件: stdio.h
参数说明:
path: 文件名,用于存储输入输出的自定义文件名。
mode: 文件打开的模式。和fopen中的模式(如r-只读, w-写)相同。
stream: 一个文件,通常使用标准流文件。
返回值:成功,则返回一个path所指定文件的指针;失败,返回NULL。(一般可以不使用它的返回值)
功能:实现重定向,把预定义的标准流文件定向到由path指定的文件中。标准流文件具体是指stdin、stdout和stderr。其中stdin是标准输入流,默认为键盘;stdout是标准输出流,默认为屏幕;stderr是标准错误流,一般把屏幕设为默认。通过调用freopen,就可以修改标准流文件的默认值,实现重定向。
#include<iostream>
#include<cstdio>
using namespace std;
int main(){freopen("7532.in", "r", stdin);freopen("7532.out", "w", stdout);//原来的代码保持不变double a, b, r;int k;cin >> a >> b;k = int(a/b);r = a - b * k;printf("%g", r);//-------------fclose(stdin);fclose(stdout);return 0;
}
相关文章:
CSP-J第二轮试题-2019年-1、2题
文章目录 参考:总结 [CSP-J2019] 数字游戏题目描述输入格式输出格式样例 #1样例输入 #1样例输出 #1 样例 #2样例输入 #2样例输出 #2 提示答案答案2 [CSP-J 2019] 公交换乘题目描述输入格式输出格式样例 #1样例输入 #1样例输出 #1 样例 #2样例输入 #2样例输出 #2 提示…...
深入理解 python 虚拟机:原来虚拟机是这么实现闭包的
深入理解 python 虚拟机:原来虚拟机是这么实现闭包的 在本篇文章当中主要从虚拟机层面讨论函数闭包是如何实现的,当能够从设计者的层面去理解闭包就再也不用死记硬背一些闭包的概念了,因为如果你理解闭包的设计原理之后,这些都是…...
【数据结构-哈希表 一】【原地哈希】:缺失的第一个正整数
废话不多说,喊一句号子鼓励自己:程序员永不失业,程序员走向架构!本篇Blog的主题是【原地哈希】,使用【数组】这个基本的数据结构来实现,这个高频题的站点是:CodeTop,筛选条件为&…...
【C++设计模式之迭代器模式】分析及示例
简介 迭代器模式是一种行为型设计模式,它提供了一种顺序访问聚合对象元素的方法,而又不需要暴露聚合对象的内部结构。迭代器模式通过将遍历算法封装在迭代器对象中,可以使得遍历过程更简洁、灵活,并且符合开闭原则。 描述 迭代…...
【代码随想录】LC 27. 移除元素
文章目录 前言一、题目1、原题链接2、题目描述 二、解题报告1、思路分析2、时间复杂度3、代码详解 三、知识风暴 前言 本专栏文章为《代码随想录》书籍的刷题题解以及读书笔记,如有侵权,立即删除。 一、题目 1、原题链接 27. 移除元素 2、题目描述 二、…...
crash工具分析dma设备内存踩踏(一)
背景介绍 我们的客户在利用我们提供的SDK参考方案开发相关产品时,在产品方案上进行一些基础老化测试时,极低概率出现kernel随机panic问题,由于场景复杂,无法单独针对特定模块或功能进行拆解来进行实验排查,只能基于已…...
C#上位机——根据命令发送
C#上位机——根据命令发送 第一步:设置窗口的布局 第二步:设置各个属性 第三步:编写各个模块之间的关系...
BEVFormer代码跑通
1 环境配置 1.1 环境安装 # 1 拉取源码 github加速代理https://ghproxy.com/ git clone https://github.com/fundamentalvision/BEVFormer.git# 2 创建虚拟环境 conda create -n bev python3.8 -y# 3 激活虚拟环境 conda activate bev# 4.1 安装torch,torchvision,torchaud…...
kafka安装
kafka安装 1 kafka概念 1.1 kafka介绍 kafka是最初有Linkedin公司开发的,是一个分布式,分区,多副本,多生产者,多订阅者,基于zookeeper协调的分布式日志系统。具有高吞吐量,可扩展性和可容错性…...
Mac上安装Java的JDK多版本管理软件jEnv
JDK的多版本管理软件主要有以下三种: jEnv jEnv 是一个命令行工具,可以帮助您管理和切换不同版本的 Java 环境。它可以让您在不同的项目之间轻松切换 Java 版本。您可以使用 jenv global 命令设置全局 Java 版本,也可以使用 jenv local 命令…...
linux常见命令以及jdk,tomcat环境搭建
目录 Is pwd cd touch cat echo vim 复制粘贴 mkdir rm cp jdk部署 1. yum list | grep jdk进行查找编辑 2.安装编辑 3.再次确认 4.判断是否安装成功 tomcat安装 1.下载压缩包,把压缩包上传至linux(可能需要yum install lrzsz) 2.解压缩unzip 压缩包名&…...
将表情存入数据库
概念: 表情是一种比较特殊的字符串,为unicode编码,unicode编码要存入数据库一般情况下,是存不了的,有两种解决方式,一种将数据表编码方式改为unicode编码方式,但是这种情况适用于功能刚开始设计…...
H桥级联型五电平三相逆变器Simulink仿真模型
💥💥💞💞欢迎来到本博客❤️❤️💥💥 🏆博主优势:🌞🌞🌞博客内容尽量做到思维缜密,逻辑清晰,为了方便读者。 ⛳️座右铭&a…...
后端解决跨域(极速版)
header(Access-Control-Allow-Origin: *); header(Access-Control-Allow-Methods:*); 代表接收全部的请求,"POST,GET"//允许访问的方式 指定域,如http://172.20.0.206//宝塔的域名,注意不是:http://wang.jingyi.icu等…...
数据结构与算法-前缀树
数据结构与算法-前缀树详解 1 何为前缀树 2 前缀树的代码表示及相关操作 1 何为前缀树 前缀树 又称之为字典树,是一种多路查找树,多路树形结构,是哈希树的变种,和hash效率有一拼,是一种用于快速检索的多叉树结构。 性质:不同字符串的相同…...
DirectX12_Windows_GameDevelop_3:Direct3D的初始化
引言 查看龙书时发现,第四章介绍预备知识的代码不太利于学习。因为它不像是LearnOpenGL那样从头开始一步一步教你敲代码,导致你没有一种整体感。如果你把它当作某一块的代码进行学习,你跟着敲会发现,总有几个变量是没有定义的。这…...
基于粒子群优化算法、鲸鱼算法、改进的淘沙骆驼模型算法(PSO/SSA/tGSSA)的微电网优化调度(Matlab代码实现)
💥💥💞💞欢迎来到本博客❤️❤️💥💥 🏆博主优势:🌞🌞🌞博客内容尽量做到思维缜密,逻辑清晰,为了方便读者。 ⛳️座右铭&a…...
数据分析篇-数据认知分析
一简介 数据认知分析,实际是对数据的整体结构和分布特征进行分析,是对整个数据外在的认识,也是数据分析的第一步。对于数据认知的分析,一般会考虑分散性、位置特性、变量的相关性等,一般会考虑平均数、方差、极差、峰…...
【力扣-每日一题】714. 买卖股票的最佳时机含手续费
class Solution { public:int maxProfit(vector<int>& prices, int fee) {//[i][0]-不持有 [i][1]-持有int mprices.size();vector<vector<int>> dp(m,vector<int>(2));dp[0][0]0; //初始状态dp[0][1]-prices[0];for(int i1;i<m;i){dp[i]…...
【代码实践】HAT代码Window平台下运行实践记录
HAT是CVPR2023上的自然图像超分辨率重建论文《activating More Pixels in Image Super-Resolution Transformer》所提出的模型。本文旨在记录在Window系统下运行该官方代码(https://github.com/XPixelGroup/HAT)的过程,中间会遇到一些问题&am…...
NS-USBLoader完整指南:Switch文件管理、RCM注入与游戏传输的一站式解决方案
NS-USBLoader完整指南:Switch文件管理、RCM注入与游戏传输的一站式解决方案 【免费下载链接】ns-usbloader Awoo Installer and GoldLeaf uploader of the NSPs (and other files), RCM payload injector, application for split/merge files. 项目地址: https://…...
电源技术周览:从微生物电池到前沿功率器件深度解析
1. 电源技术周览:从微生物电池到前沿功率器件又到了每周梳理电源技术动态的时候。这周的信息密度不小,从颇具科幻感的微生物燃料电池,到未来十年锂离子电池的市场与技术路线图,再到高压直流输电和无线充电这些与我们生活、工业息息…...
DSP28335新手避坑指南:手把手教你用CCS6.2生成10KHz SPWM(附完整工程)
DSP28335实战:从零构建10KHz SPWM的完整工程指南 第一次接触DSP28335开发板时,面对复杂的寄存器配置和编译环境问题,很多工程师都会感到无从下手。本文将带你一步步完成从CCS工程创建到SPWM波形输出的全过程,特别针对新手容易遇到…...
别再死记硬背了!手把手教你选对PPP定位模型:UC、UD、UofC、SD到底怎么用?
精密单点定位模型实战指南:如何根据场景选择UC、UD、UofC与SD 在GNSS高精度定位领域,精密单点定位(PPP)技术已成为科研与工程应用的核心工具。面对UC、UD、UofC、SD四种主流模型,许多工程师常陷入选择困境——不同模型…...
OBS高级计时器插件:如何高效管理直播时间的完整指南
OBS高级计时器插件:如何高效管理直播时间的完整指南 【免费下载链接】obs-advanced-timer 项目地址: https://gitcode.com/gh_mirrors/ob/obs-advanced-timer OBS高级计时器插件是专为OBS Studio用户设计的专业时间管理工具,通过6种智能计时模式…...
AI代码智能体突破电话验证瓶颈:从环境模拟到混合架构的实战方案
1. 项目概述:当代码智能体遇上“电话验证墙”最近在折腾Claude这类AI代码助手做自动化任务时,我发现一个挺有意思的瓶颈:它们经常在需要电话验证(Phone Verification)的环节上“卡壳”。这可不是个小问题,想…...
通过用量看板直观比较不同大模型api的token消耗效率
🚀 告别海外账号与网络限制!稳定直连全球优质大模型,限时半价接入中。 👉 点击领取海量免费额度 通过用量看板直观比较不同大模型API的Token消耗效率 对于需要持续调用大模型API的开发者或团队而言,理解并控制成本是项…...
如何利用Deep SORT实现稳定高效的多目标追踪
如何利用Deep SORT实现稳定高效的多目标追踪 【免费下载链接】deep_sort Simple Online Realtime Tracking with a Deep Association Metric 项目地址: https://gitcode.com/gh_mirrors/de/deep_sort 在计算机视觉的实际应用中,多目标追踪一直是一个技术难点…...
AI代理如何革新领导力评估:从隐藏档案任务到低成本高效测量
1. 项目概述:当AI成为你的“面试官”,领导力评估正在发生什么?如果你是一位人力资源总监,或者是一位正在为团队选拔继任者而头疼的部门负责人,那么下面这个场景你一定不陌生:为了评估一个候选人的真实领导潜…...
商家怎么弄小程序店铺
去年10月有个做茶叶生意的武夷山商家找到我,说要弄个小程序店铺。我问他需求是什么,他说"就是能让客户在线买茶"。听起来简单,但实际做下来,整个过程走了不少弯路。我把时间线记录下来,给要弄小程序店铺的商…...
