CSDN竞赛21期题解

news2024/9/27 7:25:33

总结

(PS:这次竞赛的奖励对我诱惑力感觉没多大,因为高级背包不久前才收到一个,邹老师的两本签名书也早就拿到了,程序员杂志、帆布包也都有了,扑克牌都拿了几副了,所以还是换点其他的书比较好,拿那么多的背包也用不上)。建议后面奖励如果拿重了可以换其他的,多来点深度学习之类的书籍就好了。

这次的题目难度偏低,只有T2可能数据有点问题,开始提交一个代码通过了部分用例,检查下发现有bug,修改后用例通过率变成0了,到最后没时间了只好用最开始的代码提交了。提交后发现大家都还没得分,就挺诧异的,看来还是得看运气。

题目列表

1.合并序列

题目描述

有N个单词和字符串T,按字典序输出以字符串T为前缀的所有单词。

输入描述:

输入文件第一行包含一个正整数N;
接下来N行,每行一个单词,长度不超过100;
最后一行包含字符串T。
所有字符均为小写字母。

输出描述:

按字典序升序输出答案。

输入样例:

6
na
no
ki
ki
ka
ku
k

输出样例:

ka
ki
ki
ku

分析

求前缀第一反应是trie树,当然本题只需要读入后使用string的sunstr方法直接判断前缀是否相等即可,将前缀等于T的单词存入vector中,排下序就可以输出了。主要本题的输入可能有重复的字符串,因此不能使用set存储。

代码

#include <iostream>
#include <string>
#include <sstream>
#include <vector>
#include <algorithm>
using namespace std;
int main() {
	int n;
	vector<string> str;
	string x, T;
	cin>>n;
	for (int i = 0; i < n; i++) {
		cin>>x;
		str.push_back(x);
	}
	cin>>T;
	int len = T.size();
	vector<string> res;
	for (auto t : str) {
		if (t.substr(0, len) == T) res.push_back(t);
	}
	sort(res.begin(), res.end());
	for (auto t : res) cout<<t<<endl;
	return 0;
}

2.千问万问

题目描述

给定大小为n的整数序列A.
现在会有q次询问,询问子区间的不同整数的数量。

输入描述:

第一行输入整数n,q.(1<=n,q<=1000)
第二行输入n个整数.(1<=a<=100000)
以下q行每行两个整数l,r。(1<=l,r<=100000)

输出描述:

输出区间内的整数数量。

输入样例:

10 3
1 2 3 4 5 6 7 8 9 10
1 1
1 2
1 3

输出样例:

1
2
3

分析

本题数据范围给定不大,完全可以使用hash存储10w以内每个数出现的次数,然后再使用一个前缀和数组来维护hash数组的前缀和,就可以在O(1)的时间内求出区间内的整数数量了,这样以来总的计算次数也是 O ( 1 0 5 ) O(10^5) O(105)的。

再来说下题目的bug,题目描述里说要统计不同整数的数量,而输出描述里则是说统计区间内整数的数量,这两个语义是不一致的。至于题目输入模板的bug,一开始我就删掉了模板自己写了,倒是没有注意到。这里我按照统计整数的数量去写,不管整数是否重复,可以通过三成的用例,当然我记得竞赛题目的输入范围不是从1开始的,而是从0开始的,所以下面的代码没有统计0是有问题的,但是奇怪的是如果我统计上0,用例通过率就变成0了,大概是标杆程序对区间的处理存在问题,所以存在bug的代码误打误撞的过了几个用例。

代码

#include <iostream>
#include <string>
#include <sstream>
#include <algorithm>
#include <cstring>
#include <vector>
using namespace std;
const int N = 100005;
int a[N], s[N];
int main() {
	int n, m, x;
	cin>>n>>m;
	memset(a, 0, sizeof a);
	memset(s, 0, sizeof s);
	for (int i = 0; i < n; i++) {
		cin>>x;
		a[x]++;
	}
	for (int i = 1; i <= N - 1; i++) s[i] = s[i - 1] + a[i];
	while(m--) {
		int l, r;
		cin>>l>>r;
		cout<<s[r] - s[l-1]<<endl;
	}
	return 0;
}

3.连续子数组的最大和

题目描述

给定一个整数数组 nums ,找到一个具有最大和的连续子数组(子数组最少包含一个元素),返回其最大和 。(测试用例仅做参考,我们会根据代码质量进行评分)

输入描述:

第一行输入整数数组的大小n。(1<=n<=1000)
第二行给出n个整数a。(-1e5<=a<=1e5)

输出描述:

输出答案。

输入样例:

9
-2 1 -3 4 -1 2 1 -5 4

输出样例:

6

分析

很有纪念意义的一题,经典的DP题目。第一次遇见是在17年912的考卷上,那时候DP都还没有学习。

维护一个变量存储和,当和不小于0时,就加上当前的数,否则和就等于当前的数,取遍历过程中和的最大值即可。

代码

#include <iostream>
#include <string>
#include <sstream>
#include <vector>
#include <algorithm>
using namespace std;
const int N = 100005;
int a[N];
int main() {
	int n;
	cin>>n;
	for(int i = 0; i < n; i++) cin>>a[i];
	int res = a[0];
	int cnt = 0;
	for (int i = 0 ; i < n; i++) {
		if (cnt >= 0) cnt += a[i];
		else cnt = a[i];
		res = max(res, cnt);
	}
	cout<<res<<endl;
	return 0;
}

4.降水量

题目描述

给定n个柱面的高度,表示降雨某地n块区域的海拔高度。
计算降雨之后该地最大储水面积。如果低于地平线,也就是小于0,则一定积水

输入描述:

第一行输入整数n.(1<=n<=10000)
第二行输入n个高度整数h。(-10000<=h<=10000)

输出描述:

输出答案。

输入样例:

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

输出样例:

6

分析

本题属于接雨水的变形,与接雨水问题不同的是,柱面的高度可能小于0,小于0的一定储水。

首先,考虑下什么情况下一定会储水,只要柱子左边和右边都存在比它高的柱子,就一定会储水,n个柱子的两边可以认为有两个高度为0的柱子哨兵,这样一来,高度小于0柱子的积水也会被统计上。
在这里插入图片描述

如图所示,第 i i i柱子上的积水高度等于 m i n ( l , r ) − h [ i ] min(l,r)-h[i] min(l,r)h[i],其中 l l l表示 i i i左边柱子的最大高度, r r r表示 i i i右边柱子的最大高度,只要 h [ i ] h[i] h[i]比左右两边最高的柱子高度都小,就可以积水了。因此,比较简单的一种做法就是统计下自左向右和自右向左的柱子最大高度,然后遍历一下求出每根柱子的积水之和即可。

代码

#include <iostream>
#include <string>
#include <sstream>
#include <vector>
#include <algorithm>
using namespace std;
const int N = 10005;
int h[N], l[N], r[N];
int main() {
	int n;
	cin>>n;
	for (int i = 1; i <= n; i++) cin>>h[i];
	int t = 0;
	for (int i = 1; i <= n; i++) {
		l[i] = t;
		t = max(t, h[i]);
	}
	t = 0;
	for (int i = n; i >= 1; i--) {
		r[i] = t;
		t = max(t, h[i]);
	}
	int res = 0;
	for (int i = 1; i <= n; i++) {
		t = min(l[i], r[i]);
		if (h[i] < t) res += t - h[i];
	}
	cout<<res<<endl;
	return 0;
}

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

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

相关文章

c语言tips-【c语言内存模型】

0.摘要 C语言是比较接近底层的语言&#xff0c;因此它的很多知识点是和操作系统挂钩的&#xff0c;例如它的内存模型&#xff0c;其实也是操作系统进程的内存模型&#xff0c;本文章就是解释进程&#xff0c;虚拟内存空间&#xff0c;内存模型的相关知识和它们之间的联系 1. 虚…

热交换器及一维平行流换热器分析(Matlab代码实现)

目录 &#x1f4a5;1 概述 &#x1f4da;2 运行结果 &#x1f389;3 参考文献 &#x1f468;‍&#x1f4bb;4 Matlab代码 &#x1f4a5;1 概述 首先试图对热交换器的设置进行建模&#xff0c;并获得该过程的控制方程。使用相应的控制方程并设置边界条件并获得适当的边界值…

RHCE第五天之NFS服务器详解

文章目录一、NFS服务器简介二、NFS的使用三、客户端使用autofs自动挂载四、实验练习一、NFS服务器简介 NFS&#xff08;Network File System&#xff0c;网络文件系统&#xff09;&#xff1a; 是FreeBSD支持的文件系统中的一种&#xff0c;它允许网络中的计算机&#xff08;不…

Qt / Qml 视频硬解码(CUDA)中如何实现无上传硬渲染(一)

【写在前面】 很多时候&#xff0c;我们在对视频的解码和渲染的处理都要经过以下步骤&#xff1a; 软解码&#xff0c;视频帧位于内存。 软渲染&#xff0c;需要拷贝到图像然后渲染&#xff1b;硬渲染则需要上传纹理&#xff0c;然后渲染。硬解码&#xff0c;视频帧位于显存。…

OPengl学习(四)——顶点数组

文章目录1、 问题2、步骤2.1 激活数组2.2 指定数组的数据2.3 解引用和渲染3、例子1、 问题 1、在前面我们实现一个多彩三角形&#xff0c;调用三次glvertext&#xff08;&#xff09;函数&#xff0c;如果在多边形&#xff0c;如20条边的&#xff0c;那么就要使用22次函数&…

【大数据之路】数据管理篇 《三》存储和成本管理 【搬运小结】

文章目录【大数据之路】数据管理篇 《三》存储和成本管理1.1数据压缩1.2存储治理项优化1.3生命周期管理1.3.1 生命周期管理策略1.3.2 生命周期管理策略1.4数据成本计量【大数据之路】数据管理篇 《三》存储和成本管理 1.1数据压缩 在分布式文件系统中&#xff0c;为了提高数据…

python制作课堂点名系统,从此老师对我关爱有加

前言 大家早好、午好、晚好吖 ❤ ~ 准备工作 首先我们需要准备好点名的姓名文件&#xff0c;使用的时候导入进去就可以开始点名了。 新建一个文本文档&#xff0c;将姓名设置设置好&#xff0c;如下&#xff1a; 使用系统库和第三方库都比较常规 from PyQt5.QtWidgets impo…

Attention机制的具体计算过程

一、介绍Query、Key、Value的来源一个输入&#xff0c;经过embedding位置编码后得到最终的输入X&#xff08;512维&#xff09;&#xff0c;最终的输入X与矩阵参数WQ&#xff08;512*64维&#xff09;相乘&#xff0c;得到Query&#xff1b;与矩阵参数WK&#xff08;512*64维&a…

Java反射机制

目录 反射问题的引出 Java程序在计算机中部署的三个阶段 反射的主要相关类 反射机制的优缺点 调优 反射常用类—Class 特点 常用方法 获取映射Class类对象的四种方式 类加载的三个阶段 加载阶段 Loading 链接阶段 Linking 验证 Verification 准备 Preparation 解…

OpenGL示例源码opengl_examples编译

下载好源码并创建编译目录opengl_build 打开CMake-GUI选择源码目录及二进制编译目录:

C#学习记录——【实例】读写ini文件

『知识有两种&#xff0c;一种是你知道的&#xff0c;一种是你知道在哪里能找到的&#xff01;』—— 塞缪尔约翰逊 1、概念 C#读写ini文件之前要了解的概念&#xff1a;INI就是扩展名为"INI"的文件,其实他本身是个文本文件,可以用记事本打开,主要存放的是用户所做…

axios拦截器使用和知识点补充

axios拦截器使用和知识点补充axios拦截器使用axios基地址ajax知识点补充onreadstatechange事件Ajax组成部分了解get请求与post请求区别其他请求方法了解axios拦截器使用 <link rel"stylesheet" href"./lib/bootstrap-v4.6.0.css" /><style>bod…

农业机器人研究进展

文章目录一、农业机器人二、国际农业机器人现状三、我国农业机器人发展情况四、农业机器人展望五、结束语2022年9月17-18日&#xff0c;第十一届中国智能产业高峰论坛成功在厦门举办。大会主论坛上&#xff0c;CAAI副理事长、中国工程院院士、国家农业信息化工程技术研究中心研…

Java实现二叉树

一、树 1、树简介 树是一种非线性的数据结构&#xff0c;具有n个结点其数据存储形式像一棵倒挂的树&#xff0c;树有一个根结点没有前驱结点&#xff0c;树有多个叶子结点没有后继结点&#xff0c;树有多个中间结点既有前驱结点又有后继结点。 树结构中子树之间不能有交集。 n个…

【Node.js实战】一文带你开发博客项目之联调(导入HTML、Nginx反向代理、CORS解决跨域、与前端联调)

个人简介 &#x1f440;个人主页&#xff1a; 前端杂货铺 &#x1f64b;‍♂️学习方向&#xff1a; 主攻前端方向&#xff0c;也会涉及到服务端 &#x1f4c3;个人状态&#xff1a; 在校大学生一枚&#xff0c;已拿多个前端 offer&#xff08;秋招&#xff09; &#x1f680;未…

Tapdata Cloud 场景通关系列: Oracle → MySQL 异构实时同步

【前言】作为中国的 “Fivetran/Airbyte”, Tapdata Cloud 自去年发布云版公测以来&#xff0c;吸引了近万名用户的注册使用。应社区用户上生产系统的要求&#xff0c;Tapdata Cloud 3.0 将正式推出商业版服务&#xff0c;提供对生产系统的 SLA 支撑。Tapdata 目前专注在实时数…

二叉树的遍历(非递归)

二叉树的遍历 遍历二叉树, 是指按一定的规则和顺序访问二叉树的所有结点, 使每一个结点都被访问一次, 而且只被访问一次. 由于二叉树是非线性结构, 因此, 二叉树的遍历实质上是将二叉树的各个结点排列成一个线性序列. DFS: 前序, 中序及后序. BFS: 是指沿着二叉树的宽度优先遍…

Leetcode.1806 还原排列的最少操作步数

题目链接 Leetcode.1806 还原排列的最少操作步数 题目描述 给你一个偶数 ​n​n​n​​​​​ &#xff0c;已知存在一个长度为 nnn 的排列 permpermperm &#xff0c;其中 perm[i]iperm[i] iperm[i]i​&#xff08;下标 从 0 开始 计数&#xff09;。 一步操作中&#xff0…

OLAP和OLTP的区别

OLAP和OLTP的区别 OLAP&#xff1a; (Online transaction processing):在线/联机事务处理。典型的OLTP类操作都比较简单&#xff0c;主要是对数据库中的数据进行增删改查&#xff0c;操作主体一般是产品的用户。 OLTP&#xff1a; (Online analytical processing):指联机分…

Vue新一代状态管理工具—Pinia—都2023年了,快学起来吧!

Pinia 基本介绍 Pinia 是 Vue.js 的轻量级状态管理库 官方网站&#xff1a;https://pinia.vuejs.org/ 中文文档: https://pinia.web3doc.top/introduction.html 为什么学习pinia? pinia和vuex4一样&#xff0c;也是vue 官方 状态管理工具(作者是 Vue 核心团队成员&#xff…