当前位置: 首页 > news >正文

GESP2023年12月认证C++六级( 第三部分编程题(1)闯关游戏)

参考程序代码:

#include <cstdio>
#include <cstdlib>
#include <cstring>
#include <algorithm>
#include <string>
#include <map>
#include <iostream>
#include <cmath>
using namespace std;const int N = 10005; // 最大关卡数
const int M = 105;   // 每关最大通道数
const int inf = 0x3f3f3f3f; // 一个很大的数,用于初始化int a[M], b[N], f[N]; // a[i]表示第i个通道的前进关卡数,b[i]表示离开第i关时的得分,f[i]表示到达第i关的最大得分int main() {int n, m;scanf("%d%d", &n, &m); // 读取关卡数和每关通道数for (int i = 1; i <= m; i++)scanf("%d", &a[i]); // 读取每个通道的前进关卡数(注意数组下标从1开始,方便处理)for (int i = 0; i < n; i++)scanf("%d", &b[i]); // 读取每关的得分memset(f, -0x3f, sizeof(f)); // 初始化f数组为一个很小的数,表示当前不可达状态f[0] = 0; // 初始状态,第0关可达,得分为0// 动态规划状态转移for (int i = 1; i < n; i++)for (int j = 1; j <= m; j++)if (i - a[j] >= 0) // 检查是否能从前面的某一关到达当前关f[i] = max(f[i], f[i - a[j]] + b[i - a[j]]); // 更新最大得分int ans = -inf; // 初始化最大得分为一个很小的数// 查找最大得分for (int i = 0; i < n; i++)for (int j = 1; j <= m; j++)if (i + a[j] >= n) { // 检查是否能到达最后一关或之后的关卡ans = max(ans, f[i] + b[i]); // 更新最大得分(注意这里应该加上b[n-1]之后的得分,但为了方便处理,且题目保证通关时不再额外得分,这里简化为b[i])break; // 找到一个可行解后即可跳出内层循环}cout << ans << endl; // 输出最大得分return 0;
}

参考程序2代码:

#include <iostream>
#include <vector>
#include <algorithm>
#include <climits>using namespace std;const int INF = 0x3f3f3f3f;int main() {int n, m;cin >> n >> m;vector<int> a(m); // 每个通道可以前进的关卡数for (int i = 0; i < m; ++i) {cin >> a[i];}vector<int> b(n); // 每关离开时获得的分数for (int i = 0; i < n; ++i) {cin >> b[i];}// f[i] 表示到达第 i 关时的最大分数vector<int> f(n, -INF);f[0] = 0; // 初始状态// 动态规划状态转移for (int i = 1; i < n; ++i) {for (int j = 0; j < m; ++j) {if (i - a[j] >= 0) {f[i] = max(f[i], f[i - a[j]] + b[i - a[j]]);}}}// 计算最终答案int ans = -INF;for (int i = 0; i < n; ++i) {for (int j = 0; j < m; ++j) {if (i + a[j] >= n) {ans = max(ans, f[i] + b[i]);break;}}}cout << ans << endl;return 0;
}

相关文章:

GESP2023年12月认证C++六级( 第三部分编程题(1)闯关游戏)

参考程序代码&#xff1a; #include <cstdio> #include <cstdlib> #include <cstring> #include <algorithm> #include <string> #include <map> #include <iostream> #include <cmath> using namespace std;const int N 10…...

git 新项目

新项目git 新建的项目如何进行git 配置git git config --global user.name "cc" git config --global user.email ccexample.com配置远程仓库路径 // 添加 git remote add origin http://gogs/cc/mc.git //如果配错了&#xff0c;删除 git remote remove origin初…...

系统URL整合系列视频一(需求方案)

视频 系统URL整合系列视频一&#xff08;需求方案&#xff09; 视频介绍 &#xff08;全国&#xff09;某大型分布式系统Web资源URL整合需求实现方案讲解。当今社会各行各业对软件系统的web资源访问权限控制越来越严格&#xff0c;控制粒度也越来越细。安全级别提高的同时也增…...

Vue.js 使用组件库构建 UI

Vue.js 使用组件库构建 UI 在 Vue.js 项目中&#xff0c;构建漂亮又高效的用户界面&#xff08;UI&#xff09;是很重要的一环。组件库就是你开发 UI 的好帮手&#xff0c;它可以大大提高开发效率&#xff0c;减少重复工作&#xff0c;还能让你的项目更具一致性和专业感。今天…...

计算图 Compute Graph 和自动求导 Autograd | PyTorch 深度学习实战

前一篇文章&#xff0c;Tensor 基本操作5 device 管理&#xff0c;使用 GPU 设备 | PyTorch 深度学习实战 本系列文章 GitHub Repo: https://github.com/hailiang-wang/pytorch-get-started PyTorch 计算图和 Autograd 微积分之于机器学习Computational Graphs 计算图Autograd…...

51单片机入门_05_LED闪烁(常用的延时方法:软件延时、定时器延时;while循环;unsigned char 可以表示的数字是0~255)

本篇介绍编程实现LED灯闪烁&#xff0c;需要学到一些新的C语言知识。由于单片机执行的速度是非常快的&#xff0c;如果不进行延时的话&#xff0c;人眼是无法识别(停留时间要大于20ms)出LED灯是否在闪烁所以需要学习如何实现软件延时。另外IO口与一个字节位的数据对应关系。 文…...

如何获取sql数据中时间的月份、年份(类型为date)

可用自带的函数month来实现 如&#xff1a; 创建表及插入数据&#xff1a; create table test (id int,begindate datetime) insert into test values (1,2015-01-01) insert into test values (2,2015-02-01) 执行sql语句,获取月份&#xff1a; select MONTH(begindate)…...

【单层神经网络】softmax回归的从零开始实现(图像分类)

softmax回归 该回归分析为后续的多层感知机做铺垫 基本概念 softmax回归用于离散模型预测&#xff08;分类问题&#xff0c;含标签&#xff09; softmax运算本质上是对网络的多个输出进行了归一化&#xff0c;使结果有一个统一的判断标准&#xff0c;不必纠结为什么要这么算…...

使用开源项目:pdf2docx,让PDF转换为Word

目录 1.安装python 2.安装 pdf2docx 3.使用 pdf2docx 转换 PDF 到 Word pdf2docx&#xff1a;GitCode - 全球开发者的开源社区,开源代码托管平台 环境&#xff1a;windows电脑 1.安装python Download Python | Python.org 最好下载3.8以上的版本 安装时记得选择上&#…...

保姆级教程Docker部署KRaft模式的Kafka官方镜像

目录 一、安装Docker及可视化工具 二、单节点部署 1、创建挂载目录 2、运行Kafka容器 3、Compose运行Kafka容器 4、查看Kafka运行状态 三、集群部署 四、部署可视化工具 1、创建挂载目录 2、运行Kafka-ui容器 3、Compose运行Kafka-ui容器 4、查看Kafka-ui运行状态 …...

ChatGPT提问技巧:行业热门应用提示词案例--咨询法律知识

ChatGPT除了可以协助办公&#xff0c;写作文案和生成短视频脚本外&#xff0c;和还可以做为一个法律工具&#xff0c;当用户面临一些法律知识盲点时&#xff0c;可以向ChatGPT咨询获得解答。赋予ChatGPT专家的身份&#xff0c;用户能够得到较为满意的解答。 1.咨询法律知识 举…...

openRv1126 AI算法部署实战之——Tensorflow模型部署实战

在RV1126开发板上部署Tensorflow算法&#xff0c;实时目标检测RTSP传输。视频演示地址 rv1126 yolov5 实时目标检测 rtsp传输_哔哩哔哩_bilibili ​ 一、准备工作 从官网下载tensorflow模型和数据集 手动在线下载&#xff1a; https://github.com/tensorflow/models/b…...

STM32 TIM定时器配置

TIM简介 TIM&#xff08;Timer&#xff09;定时器 定时器可以对输入的时钟进行计数&#xff0c;并在计数值达到设定值时触发中断 16位计数器、预分频器、自动重装寄存器的时基单元&#xff0c;在72MHz计数时钟下可以实现最大59.65s的定时 不仅具备基本的定时中断功能&#xff…...

51单片机 05 矩阵键盘

嘻嘻&#xff0c;LCD在RC板子上可以勉强装上&#xff0c;会有一点歪。 一、矩阵键盘 在键盘中按键数量较多时&#xff0c;为了减少I/O口的占用&#xff0c;通常将按键排列成矩阵形式&#xff1b;采用逐行或逐列的“扫描”&#xff0c;就可以读出任何位置按键的状态。&#xf…...

SSRF 漏洞利用 Redis 实战全解析:原理、攻击与防范

目录 前言 SSRF 漏洞深度剖析 Redis&#xff1a;强大的内存数据库 Redis 产生漏洞的原因 SSRF 漏洞利用 Redis 实战步骤 准备环境 下载安装 Redis 配置漏洞环境 启动 Redis 攻击机远程连接 Redis 利用 Redis 写 Webshell 防范措施 前言 在网络安全领域&#xff0…...

kubernetes学习-配置管理(九)

一、ConfigMap &#xff08;1&#xff09;通过指定目录&#xff0c;创建configmap # 创建一个config目录 [rootk8s-master k8s]# mkdir config[rootk8s-master k8s]# cd config/ [rootk8s-master config]# mkdir test [rootk8s-master config]# cd test [rootk8s-master test…...

python 语音识别

目录 一、语音识别 二、代码实践 2.1 使用vosk三方库 2.2 使用SpeechRecognition 2.3 使用Whisper 一、语音识别 今天识别了别人做的这个app,觉得虽然是个日记app 但是用来学英语也挺好的,能进行语音识别,然后矫正语法,自己说的时候 ,实在不知道怎么说可以先乱说,然…...

一文速览DeepSeek-R1的本地部署——可联网、可实现本地知识库问答:包括671B满血版和各个蒸馏版的部署

前言 自从deepseek R1发布之后「详见《一文速览DeepSeek R1&#xff1a;如何通过纯RL训练大模型的推理能力以比肩甚至超越OpenAI o1(含Kimi K1.5的解读)》」&#xff0c;deepseek便爆火 爆火以后便应了“人红是非多”那句话&#xff0c;不但遭受各种大规模攻击&#xff0c;即便…...

[mmdetection]fast-rcnn模型训练自己的数据集的详细教程

本篇博客是由本人亲自调试成功后的学习笔记。使用了mmdetection项目包进行fast-rcnn模型的训练&#xff0c;数据集是自制图像数据。废话不多说&#xff0c;下面进入训练步骤教程。 注&#xff1a;本人使用linux服务器进行展示&#xff0c;Windows环境大差不差。另外&#xff0…...

1. Kubernetes组成及常用命令

Pods(k8s最小操作单元)ReplicaSet & Label(k8s副本集和标签)Deployments(声明式配置)Services(服务)k8s常用命令Kubernetes(简称K8s)是一个开源的容器编排系统,用于自动化应用程序的部署、扩展和管理。自2014年发布以来,K8s迅速成为容器编排领域的行业标准,被…...

利用CircuitPython内置传感器实现CPU温度监控与本地日志记录

1. 项目概述&#xff1a;从芯片温度到数据洞察 在嵌入式项目里&#xff0c;给设备“把脉”是基本功。CPU温度&#xff0c;这个看似简单的数据点&#xff0c;其实是窥探硬件运行状态的绝佳窗口。它不仅能告诉你芯片是不是在“发烧”&#xff0c;更能间接反映环境变化、负载情况&…...

别再手动数脉冲了!用STM32定时器编码器模式搞定增量编码器(附CubeMX配置)

STM32硬件编码器模式实战&#xff1a;精准捕获增量编码器信号的工程指南 在电机控制、机器人关节定位和精密测量系统中&#xff0c;增量式编码器作为核心反馈元件&#xff0c;其信号处理质量直接影响整个系统的控制精度。传统的中断计数方式在高速脉冲场景下往往捉襟见肘&#…...

基于Next.js全栈技术构建本地即时交易平台:架构设计与核心实现

1. 项目概述&#xff1a;一个面向本地市场的即时交易平台最近在逛GitHub的时候&#xff0c;发现了一个挺有意思的项目&#xff0c;叫marketmenow。光看这个名字&#xff0c;你大概就能猜到它的方向——一个“现在就能交易的市场”。没错&#xff0c;这是一个旨在构建本地化、即…...

从零搭建CFD-DEM耦合环境:OpenFOAM与PFC3D在WSL2下的实战部署指南

1. 环境准备&#xff1a;WSL2与Ubuntu基础配置 第一次接触CFD-DEM耦合仿真的同学&#xff0c;建议从Windows系统起步。微软的WSL2&#xff08;Windows Subsystem for Linux&#xff09;现在已经能完美支持Ubuntu环境&#xff0c;实测比虚拟机流畅得多。我去年在联想小新Pro16上…...

SAP MIGO BADI增强实战:从自定义表到屏幕集成的完整指南

1. SAP MIGO BADI增强实战入门 第一次接到MIGO屏幕增强需求时&#xff0c;我完全理解那种既兴奋又忐忑的心情。兴奋是因为终于有机会深入SAP核心模块的增强开发&#xff0c;忐忑则是因为MIGO作为物料管理的核心事务&#xff0c;任何改动都可能影响整个业务流程。经过多个项目的…...

从RunwayML转投Pika Labs?我对比了5个关键场景后的真实体验

从RunwayML转投Pika Labs&#xff1f;5个关键场景下的深度对比与选型指南 当AI视频生成工具如雨后春笋般涌现&#xff0c;创作者们面临的最大挑战不再是技术获取&#xff0c;而是如何在众多选项中做出明智选择。RunwayML作为行业先驱积累了稳定用户群&#xff0c;而Pika Labs凭…...

特斯拉Model 3车主必看:用华为随行WiFi+流量卡,低成本搞定车载WiFi(附Type-C供电方案)

特斯拉Model 3车主必看&#xff1a;低成本车载WiFi实战指南 特斯拉Model 3的车载娱乐系统依赖网络连接&#xff0c;但官方高级娱乐服务的月费让不少车主犹豫。更糟的是&#xff0c;部分地区的4G信号覆盖不佳&#xff0c;导致在线音乐、实时路况等功能形同虚设。本文将分享一套经…...

半导体光刻OPC技术:稀疏模型到网格模型的转换实践

1. 光学邻近效应校正&#xff08;OPC&#xff09;技术演进背景在半导体制造的光刻工艺中&#xff0c;光学邻近效应校正&#xff08;Optical Proximity Correction, OPC&#xff09;是一项至关重要的分辨率增强技术。随着制程节点不断微缩至65nm以下&#xff0c;传统的光学模型面…...

数据库查询语句的封装思路

import yamldef yamlread(path): # 打开并读取YAML文件with open(path, r, encodingutf-8) as file:config yaml.safe_load(file)return configc创建一个文件操作方法读取文件信息class dboperations:def __init__(self, config_pathrD:\PycharmProjects\PythonProject\config…...

【51单片机】直流电机PWM调速实战:从驱动电路到闭环控制

1. 直流电机驱动基础与硬件选型 第一次玩直流电机时&#xff0c;我直接拿杜邦线把电机接在51单片机的IO口上&#xff0c;结果电机纹丝不动&#xff0c;还差点烧了芯片。这个教训让我明白&#xff1a;驱动电路是电机控制的第一道门槛。常见的直流电机工作电压通常在3-6V&#xf…...