第五届“传智杯”全国大学生计算机大赛(练习赛)水题题解

目录

复读

题目描述

输入格式

输出格式

输入输出

说明/提示

源代码 

时钟

题目描述

输入格式

输出格式

输入输出

说明/提示

源代码 

平等的交易 

题目描述

输入格式

输出格式

输入输出

说明/提示

源代码

清洁工

题目描述

输入格式

输出格式

输入输出样例

说明/提示

源代码


复读

题目描述

给定若干个字符串,不定数量,每行一个。有些字符串可能出现了多次。如果读入一个字符串后,发现这个字符串以前被读入过,则这个字符串被称为前面相同的字符串的复读,这个字符串被称为复读字符串。相应的,每个首次出现的字符串就是非复读字符串

举个例子,

abc
def
abc
abc
abc

第 1,3,4,51,3,4,5 行是字符串 abc,那么 3,4,53,4,5 行的字符串会被称为“复读”。

请你把所有的非复读字符串,按照行号从小到大的顺序,依次拼接为一个长串并输出。

输入格式

多个字符串,每行一个,含义见题目描述。

注意:如果这个字符串是 0,说明所有字符串都读完了。这个 0 不认为是一个“非复读字符串”。

输出格式

共一行,表示所有非复读字符串,按照行号从小到大依次连接的结果。

输入输出

输入 

cc
b
a
cc
0

输出 

ccba

说明/提示

【数据范围】

字符串的个数不超过 500 个,字符串总长度不超过 50000,每个字符串中只包含小写字母、数字、 . 、! 和 &,不包含空格等特殊符号。

源代码 

标准水题,查重字符串,重复不接尾,对于字符串数组输出即可

#include <iostream>
#include <vector>
#include <algorithm>
using namespace std;
vector<string> A;
int main()
{
	string s;
	while(cin >> s,s != "0")
	{
		vector<string>::iterator it = find(A.begin(),A.end(),s);
		if(it != A.end())A.push_back(s);
	}
	for(int i = 0;i < A.size();i ++ )cout << A[i];	
	return 0;		
	
}

时钟

题目描述

你有一个电子钟,可以显示 0:00 到 23:59 之间的所有时间,以数字的形式显示。其中小时是 0 到 23(0 时会显示一个 0,而 1 到 9 时不会显示前导 0),分钟是 00 到 59(0 到 9 分都会显示前导 0)。任何时刻,电子钟都会显示三个或者四个 00 到 99 的数字。如果在某时刻,这些数字依次组成了一个等差数列,则这个时刻被称为“好时刻”。

你感觉很无聊,从 0:00 时刻开始盯着这个电子钟。一共盯了 xx 分钟。请问整个过程中,"好时刻"来临了多少次(算上开头和结尾)?

输入格式

一个不超过 10^9 的非负整数。

输出格式

请输出"好时刻"来临了多少次?

输入输出

输入 

120

输出 

10

输入 

2880

输出 

79

输入 

987654321

输出 

26748975

说明/提示

【样例解释】

你观察了 2 个小时,其中这些“好时刻”来临了:

0:00
0:12
0:24
0:36
0:48
1:11
1:23
1:35
1:47
1:59

一共是 10 个。

源代码 

最后一个数据点把暴力做法卡掉了,因此我们可以采用打表的思维,由打表可得,算上从0:00-23:59,一共有39个“好时刻”,因此,我们只需要不断的卡掉1400即可,卡掉一个ans就加39,因此,即使数据为10^9左右,我们处理数据的次数也因1400而优化了许多,所以不会TLE

#include <iostream>
using namespace std;
typedef long long ll;
int main()
{
	ll n;                     
	scanf("%lld",&n);
	ll sum = 0,ans = 0;
	while(n > 1439)
	{
		n = n - 1440;
		ans += 39;
	}
	for(ll i = 0;sum <= n;i ++,sum ++ )
	{
		if(i == 1440)i = 0;
		if(i == 0 || i == 12 || i == 24 || i == 36 || i == 48 || i == 71 || i == 83 || i == 95 || i == 107 || i == 119 || i == 130 || i == 142 || i == 154 || i == 166 || i == 178 || i == 201 || i == 213 || i == 225 || i == 237 || i == 260 || i == 272 || i == 284 || i == 296 || i == 331 || i == 343 || i == 355 || i == 390 || i == 402 || i == 414 || i == 461 || i == 473 || i == 520 || i == 532 || i == 591 || i == 671 || i == 754 || i == 837 || i == 1342 || i == 1425)ans ++ ;
	}	
	printf("%lld",ans);
}

平等的交易 

题目描述

你有 n 道具可以买,其中第 i 的价格为 ai​。

你有 w 元钱。你仅能用钱购买其中的一件商道具。当然,你可以拿你手中的道具换取其他的道具,只是这些商道具的价值之和,不能超过你打算交换出去的道具。你可以交换无数多次道具。道具的价值可能是 0,但是你不能使用空集换取价值为 0 的商品。

请问,在这个条件下,最多可以换取多少件道具?

输入格式

第一行一个正整数 n,表示道具个数。

接下来一行 n 个正整数,表示 an​。

接下来一行 1 个正整数,表示 w。

输出格式

一个正整数,表示答案。

输入输出

输入 

3 
1 1 2
5

输出 

2

说明/提示

【样例解释】

买价值为 2 的道具,并交换为两个价值为 1 的道具。

【数据范围及约束】

测试数据满足,1≤n≤106,0≤ai​≤10^9,1≤w≤2×10^9。

源代码

非常简单的一道题目,连二分都不用,我们只需要对于所有商品进行升序的排序,而后从队尾开始查,只要有商品的价值小于等于w,那么我们可以将其买下,更新w = a[i],ans = 1(ans初始化为0),利用前缀和思想处理排序后的数组,而后对于我们所买的商品的前一个下标开始向前遍历前缀和数组,若是前缀和数组s[i]的值小于w,证明我们手中的价值足以购买前i件商品,则答案更新为ans和i之间更大的值(因为i可能为1)

#include <iostream>
#include <vector>
#include <algorithm>
using namespace std;
const int N = 1000000 + 10;
typedef long long ll;
ll a[N],s[N],n,w,ans = 0,idx;
int main()
{
	scanf("%lld",&n);
	for(ll i = 1;i <= n;i ++ )scanf("%lld",&a[i]);
	scanf("%lld",&w);
	sort(a + 1,a + 1 + n);
	for(ll i = 1;i <= n;i ++ )s[i] = s[i - 1] + a[i];
	for(ll i = n;i >= 1;i -- )
	{
		if(w > a[i])
		{
			ans = 1;
			w = a[i];
			idx = i - 1;
			break;
		}
	}
	for(ll i = idx;i >= 1;i -- )
	{
		if(w >= s[i])
		{
			ans = max(ans,i);
			break;
		}
	}
	cout << ans << endl;
	return 0;
}

清洁工

题目描述

有一个 n×n 的地块,一个连续 i 分钟没人经过的地面在第 i 分钟会落上 i 个单位的灰,有人经过时不会落灰但灰也不会清零,在人走后第一分钟又会落上一个单位的灰,以此类推。你在这个  n×n 的范围内移动,你的移动轨迹可以描述为一个由 N,S,W,E 组成的字符串,每个字母分别表示上、下、左、右。这个人一开始在点 (x,y),每一分钟移动一步。

求最后每一个位置上落下的灰的量。

本题中的上和右分别表示 y 轴正方向和 x 轴正方向。保证你没有超过移动的范围。

输入格式

第一行四个正整数 n,m,x,y,含义如题面所示,其中 x,y 表示横纵坐标,不是数组下标。
第二行一个长度为 m 的字符串,表示你的移动序列。

输出格式

共n 行,每行 n 个数,第 i 行的第 j 个数表示坐标 (j,n−i+1) 上的灰的数量

输入输出样例

输入 

5 4 1 1
NENW

输出 

10 10 10 10 10 
10 10 10 10 10 
10 6 10 10 10 
4 4 10 10 10 
6 10 10 10 10 

输入 

7 14 1 1
NENENENENESSSS

输出

105 105 105 105 105 105 105 
105 105 105 105 55 61 105 
105 105 105 49 51 69 105 
105 105 51 49 105 79 105 
105 61 55 105 105 91 105 
79 69 105 105 105 105 105 
91 105 105 105 105 105 105 

输入 

10 70 2 2
NWSNSNNNSNNSSNNSENNNNEESNWSESESSWENNSEWESWWWESEEESENNSENWNESNWSNNNEESS

输出 

2485 2485 2485 2485 2485 2485 2485 2485 2485 2485 
2485 1407 1205 1267 2485 2485 2485 2485 2485 2485 
2485 1435 1281 1167 2485 2485 2485 2217 2281 2347 
2485 1465 2485 1255 1041 2485 2485 2155 2485 2415 
1557 1497 2485 2485 969 1177 2485 1733 1807 2485 
1471 1531 1315 907 935 1267 2485 1473 1647 2485 
1631 2485 2485 1357 1381 1407 1435 1499 1645 2485 
2021 2347 2485 2485 2485 2485 1465 1497 2485 2485 
2087 2415 2485 2485 2485 2485 2485 2485 2485 2485 
2485 2485 2485 2485 2485 2485 2485 2485 2485 2485 

输入 

5 4 2 1
NENW

输出 

10 10 10 10 10 
10 10 10 10 10 
10 10 6 10 10 
10 4 4 10 10 
10 6 10 10 10 

说明/提示

本题 y 轴朝上,x 轴朝右,样例输出中的左下角表示 (1,1),第一分钟你在初始点处,第二分钟移动到相应的位置,第 m+1 分钟移动到最后一个点,但是总共只有 m 分钟,因此最后一个点不受移动的影响


样例 1 解释:

你的移动路径为 (1,1)→(1,2)→(2,2)→(2,3)→(1,3),共 4 分钟。

对于第 1 分钟,(1,1) 灰层数不变,其余点被落下了 1 层灰。

对于第 2 分钟,(1,2) 灰层数不变,(1,1) 被落下了 1 层灰,其余点落下 2 层灰。

对于第 3 分钟,(2,2) 灰层数不变,(1,1) 落下 2 层灰,(1,2)(1,2) 落下 1 层灰,其余点落下 3 层灰。

对于第 4 分钟,(2,3) 灰层数不变,(1,1) 落下 3 层灰,(1,2) 落下 2 层灰,(2,2) 落下 1 层灰,其余点落下 4 层灰。

注意最后你移动到了 (1,3),但是时间只有 4 分钟,所以实际上不会对 (1,3) 造成影响。初始点不一定在 (1,1)。

1≤n≤50,1≤m≤1000。

源代码

no 记忆化路径处理

no 二维差分数组处理

no 坐标变幻公式推导

暴力是一种美学

二维数组的大小very small,所以我们不必使用二维差分进行处理,大不了重复遍历就完事儿,只要它不是我们脚下的位置,那么灰尘变化数组ddust则++,反之置为0,在处理过程之中对于sdust数组加上ddust即可,输出也不用管坐标的变换,按照题目输出即可(共n 行,每行 n 个数,第 i 行的第 j 个数表示坐标 (j,n−i+1) 上的灰的数量)

#include <iostream>
using namespace std;
const int N = 1000 + 10;
int sdust[N][N],ddust[N][N];
int n,m,x,y;
string s;
int main()
{
	ios::sync_with_stdio(false);
	cin.tie(0);
	cout.tie(0); 
	cin >> n >> m >> x >> y >> s;
	for(int idx = 0;idx < s.size();idx ++ )
	{
		for(int i = 1;i <= n;i ++ )
		{
			for(int j = 1;j <= n;j ++ )
			{
				if(i != x || j != y)
				{
					ddust[i][j] ++ ;
					sdust[i][j] += ddust[i][j];
				}
				else ddust[i][j] = 0;
			}
		} 
		if(s[idx] == 'N')y ++;
		else if(s[idx] == 'S')y -- ;
		else if(s[idx] == 'W')x -- ;
		else if(s[idx] == 'E')x ++ ;
	}
	for(int i = 1;i <= n;i ++ )
	{
		for(int j = 1;j <= n;j ++ )
		{
			cout << sdust[j][n - i + 1] << ' ';
		}
		cout << endl;
	}
	return 0;
}

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

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

相关文章

【机器学习案列】车牌自动识别系统:基于YOLO11的高效实现

&#x1f9d1; 博主简介&#xff1a;曾任某智慧城市类企业算法总监&#xff0c;目前在美国市场的物流公司从事高级算法工程师一职&#xff0c;深耕人工智能领域&#xff0c;精通python数据挖掘、可视化、机器学习等&#xff0c;发表过AI相关的专利并多次在AI类比赛中获奖。CSDN…

SpringBoot(二)—— yaml配置文件

接上篇&#xff0c;我们对SpringBoot有了基本的了解&#xff0c;接下来探究配置文件。 目录 二、配置文件 1. SpringBoot热部署 2. 配置文件 2.1 配置文件的作用 2.2 YAML 配置文件 2.3 YAML 与 XML 比较 3. YAML语法 3.1 键值对 3.2 值的写法 3.3 对象/Map&#x…

NFV架构

通信&#xff08;CT&#xff09;的NFV技术是借鉴了IT行业的云计算概念&#xff0c;实际大规模应用在4G时代。 区别是增加了以下几点 1、NFVI是openstack的电信增强版本&#xff0c;除了nova cinder nuetru等增加了电信专用组件。 2、设计增加了mano&#xff0c;包括了VIM、NFVO…

关于Edge浏览器的设置

这里记录几条个人比较习惯的使用浏览器方式的设置&#xff0c;主要是edge浏览器 1. 黑背景色 修改整个浏览器的背景色为黑色&#xff0c;而不是主题&#xff0c;只有边框颜色改变地址栏输入edge://flags/#enable-force-dark&#xff0c;将Default 改为 Enabled&#xff1b;如…

Elasticsearch:什么是查询语言?

查询语言定义 查询语言包括数据库查询语言 (database query language - DQL)&#xff0c;是一种用于查询和从数据库检索信息的专用计算机语言。它充当用户和数据库之间的接口&#xff0c;使用户能够管理来自数据库管理系统 (database management system - DBMS) 的数据。 最广…

Android使用PorterDuffXfermode模式PorterDuff.Mode.SRC_OUT橡皮擦实现马赛克效果,Kotlin(3)

Android使用PorterDuffXfermode模式PorterDuff.Mode.SRC_OUT橡皮擦实现马赛克效果&#xff0c;Kotlin&#xff08;3&#xff09; import android.content.Context import android.graphics.Bitmap import android.graphics.BitmapFactory import android.graphics.Canvas impor…

《信管通低代码信息管理系统开发平台》Linux环境安装说明

1 简介 信管通低代码信息管理系统应用平台提供多环境软件产品开发服务&#xff0c;包括单机、局域网和互联网。我们专注于适用国产硬件和操作系统应用软件开发应用。为事业单位和企业提供行业软件定制开发&#xff0c;满足其独特需求。无论是简单的应用还是复杂的系统&#xff…

jetson Orin nx + yolov8 TensorRT 加速量化 环境配置

参考【Jetson】Jetson Orin NX纯系统配置环境-CSDN博客 一 系统环境配置&#xff1a; 1.更换源&#xff1a; sudo vi /etc/apt/sources.list.d/nvidia-l4t-apt-source.list2.更新源&#xff1a; sudo apt upgradesudo apt updatesudo apt dist-upgrade sudo apt-get updat…

Burp炮台实现(动态ip发包)

基本步骤 1.使用 zmap 爬取大量代理ip 2.使用py1脚本初步筛选可用ip 3.利用py2脚本再次筛选对目标网站可用ip&#xff08;不带payload安全检测&#xff09; 4.配置 burp 插件并加载收集到的代理池 5.加载payload&#xff0c;开始爆破 Zmap kali安装 sudo apt update apt …

springboot495基于java的物资综合管理系统的设计与实现(论文+源码)_kaic

摘 要 如今社会上各行各业&#xff0c;都喜欢用自己行业的专属软件工作&#xff0c;互联网发展到这个时候&#xff0c;人们已经发现离不开了互联网。新技术的产生&#xff0c;往往能解决一些老技术的弊端问题。因为传统物资综合管理系统信息管理难度大&#xff0c;容错率低&am…

STM32-笔记16-定时器中断点灯

一、实验目的 使用定时器 2 进行中断点灯&#xff0c;500ms LED 灯翻转一次。 二&#xff0c;定时器溢出时间计算 Tout&#xff1a;定时器溢出时间 Ft&#xff1a;定时器的时钟源频率 ARR&#xff1a;自动重装载寄存器的值 PSC&#xff1a;预分频器寄存器的值 例如&#xff0c…

【MySQL】 SQL优化讲解

一、优化前的思考 在定位到慢查询后&#xff0c;面试官常问如何优化或分析慢查询的SQL语句。若存在聚合查询、多表查询&#xff0c;可尝试优化SQL语句结构&#xff0c;如多表查询可新增临时表&#xff1b;若表数据量过大&#xff0c;可添加索引&#xff0c;但添加索引后仍慢则…

C/C++ 数据结构与算法【栈和队列】 栈+队列详细解析【日常学习,考研必备】带图+详细代码

一、介绍 栈和队列是限定插入和删除只能在表的“端点”进行的线性表&#xff0c;是线性表的子集&#xff0c;是插入和删除位置受限的线性表。 &#xff08;操作受限的线性表&#xff09; 二、栈 1&#xff09;概念&#xff1a; 栈(stack)是一个特殊的线性表&#xff0c;是限…

【HarmonyOS应用开发——ArkTS语言】购物商城的实现【合集】

目录 &#x1f60b;环境配置&#xff1a;华为HarmonyOS开发者 &#x1f4fa;演示效果&#xff1a; &#x1f4d6;实验步骤及方法&#xff1a; 1. 在src/main/ets文件中创建components文件夹并在其中创建Home.ets和HomeProduct.ets文件。​ 2. 在Home.ets文件中定义 Home 组…

连锁餐饮行业数据可视化分析方案

引言 随着连锁餐饮行业的迅速发展&#xff0c;市场竞争日益激烈。企业需要更加精准地把握运营状况、消费者需求和市场趋势&#xff0c;以制定科学合理的决策&#xff0c;提升竞争力和盈利能力。可视化数据分析可以帮助连锁餐饮企业整合多源数据&#xff0c;通过直观、动态的可…

学习threejs,THREE.RingGeometry 二维平面圆环几何体

&#x1f468;‍⚕️ 主页&#xff1a; gis分享者 &#x1f468;‍⚕️ 感谢各位大佬 点赞&#x1f44d; 收藏⭐ 留言&#x1f4dd; 加关注✅! &#x1f468;‍⚕️ 收录于专栏&#xff1a;threejs gis工程师 文章目录 一、&#x1f340;前言1.1 ☘️THREE.RingGeometry 圆环几…

计算机网络实验室建设方案

一、计算机网络实验室拓扑结构 计算机网络综合实验室解决方案&#xff0c;是面向高校网络相关专业开展教学实训的综合实训基地解决方案。教学实训系统采用 B&#xff0f;S架构&#xff0c;通过公有云教学实训平台在线学习模式&#xff0c;轻松实现网络系统建设与运维技术的教学…

ThinkPHP 8开发环境安装

【图书介绍】《ThinkPHP 8高效构建Web应用》-CSDN博客 《ThinkPHP 8高效构建Web应用 夏磊 编程与应用开发丛书 清华大学出版社》【摘要 书评 试读】- 京东图书 1. 安装PHP8 Windows系统用户可以前往https://windows.php.net/downloads/releases/archives/下载PHP 8.0版本&am…

Nmap基础入门及常用命令汇总

Nmap基础入门 免责声明&#xff1a;本文单纯分享技术&#xff0c;请大家使用过程中遵守法律法规~ 介绍及安装 nmap是网络扫描和主机检测的工具。作为一个渗透测试人员&#xff0c;必不可少的就是获取信息。那么nmap就是我们从互联网上获取信息的途径&#xff0c;我们可以扫描互…

使用openvino加速部署paddleocr文本方向分类模型(C++版)

使用openvino加速部署paddleocr文本方向分类模型(C++版) 大体流程方向分类器在openvino上的部署代码C++大体流程 原始图像: 先resize 再归一化 方向分类器在openvino上的部署代码C++ #include <iostream> #include <string>#include <vector> #i…