2023年12月GESP C++七级编程题转Python真题解析

七、2023年12月GESP C++(Python)七级编程题

2023年12月GESP Python最高六级,但C++与Python同级编程题相同。本篇引用2023年12月GESPC++七级编程题,用Python实现。

【七级编程题1】

【试题名称】:商品交易

时间限制:1.0 s

内存限制:128.0 MB

【问题描述】

市场上共有N种商品,编号从0N-1,其中,第i种商品价值vi元。

现在共有M个商人,编号从0M-1。在第j个商人这,你可以使用第xj种商品交换第yj种商品。每个商人都会按照商品价值进行交易,具体来说,如果vxj>vyj,他将会付给你vyj-vxj元钱;否则,那么你需要付给商人vxj-vyj元钱。除此之外,每次交易商人还会收取1元作为手续费,不论交易商品的价值孰高孰低。

你现在拥有商品a,并希望通过一些交换来获得商品b。请问你至少要花费多少钱?(当然,这个最小花费也可能是负数,这表示你可以在完成目标的同时赚取一些钱。)

【输入描述】

第一行四个整数N,M,a,b,分别表示商品的数量、商人的数量、你持有的商品以及你希望获得的商品。保证0a,bN,保证ab

第二行N个用单个空格隔开的正整数v0,v1,…,vN-1,依次表示每种商品的价值。保证1vi≤10⁹

接下来M行,每行两个整数xj,yj,表示第j个商人愿意使用第xj种商品交换第yj种商品。保证0xj,yjN 保证xjyj

【输出描述】

输出一行一个整数,表示最少的花费。特别地,如果无法通过交换换取商品b,请输出No solution

【数据规模】

对于30%的测试点,保证N≤10M≤20

对于70%的测试点,保证N≤10³M≤10⁴

对于100%的测试点,保证N≤10⁵M≤2×10⁵

【分析】

bfs算法计算最短路径(交换次数),设交换k次。价格为v0,v1,…,vk,其中v0为源价格vavk为目标价格vb,所需费用为:

fee = k*1+(v1-v0)+(v2-v1)+…+(vk-1-vk-2)+(vk-vk-1) =k+vk-v0=k+vb-va

bfs时间复杂度O(M+N)2×10⁵+10⁵≤10⁶,不会超时。

【完整代码】
def bfs(src):qh = 0qt = 1queue[qt] = srcmin_dist[src] = 0while qh < qt:qh += 1u = queue[qh]for v in edge[u]:if min_dist[u] + 1 < min_dist[v]:min_dist[v] = min_dist[u] + 1qt += 1queue[qt] = vn, m, src, dst = [int(i) for i in input().split()]     # 输入第1行4个参数
val = [int(i) for i in input().split()]                # 输入第2行n个参数,各商品价值
min_dist = [1000000000] * n                            # 10⁹大大于n≤10⁵
queue = [0] * (n + 1)
edge = [[] for i in range(n)]                          # 不能用[]*n,n行空列表
for _ in range(m):x, y = [int(i) for i in input().split()]           # m行成对参数edge[x].append(y)                                  # y添加到edge的x行
bfs(src)                                               # 广搜求最短距离(交换次数)
if min_dist[dst] > n:                                  # 距离大于n,超过商品数,无法通过交换换取print('No solution')
else:print(min_dist[dst] - val[src] + val[dst])
【运行结果】

【七级编程题2】

【试题名称】:纸牌游戏

时间限制:1.0 s

内存限制:128.0 MB

【问题描述】

你和小杨在玩一个纸牌游戏。

你和小杨各有3张牌,分别是012。你们要进行N轮游戏,每轮游戏双方都要出一张牌,并按1战胜02战胜10战胜2的规则决出胜负。第i轮的胜者可以获得2ai分,败者不得分,如果双方出牌相同,则算平局,二人都可获得ai(i=1,2,…,N)

玩了一会后,你们觉得这样太过于单调,于是双方给自己制定了不同的新规则。小杨会在整局游戏开始前确定自己全部n轮的出牌,并将他的全部计划告诉你;而你从第2轮开始,要么继续出上一轮出的牌,要么记一次换牌。游戏结束时,你换了t次牌,就要额外扣b1+b2+…+bt分。

请计算出你最多能获得多少分。

【输入描述】

第一行一个整数N,表示游戏轮数。

第二行N个用单个空格隔开的非负整数a1,a2,…,aN,意义见题目描述。

第三行N-1个用单个空格隔开的非负整数b1,b2,…,bN-1,表示换牌的罚分,具体含义见题目描述。由于游戏进行N轮,所以你至多可以换N-1次牌。

第四行N个用单个空格隔开的整数c1,c2,…,cN,依次表示小杨从第1轮至第N轮出的牌。保证ci∈0,1,2

【输出描述】

一行一个整数,表示你最多获得的分数。

【数据规模】

对于30%的测试点,保证N15

对于60%的测试点,保证N100

对于所有测试点,保证N≤1,000;保证0≤ai,bi≤10⁶

【分析】

由于数据N≤1,000,牌只有3张,采用枚举法也不会超时。本篇采用动态规划算法获得最优解

时间复杂度O(3N²)3×1000²<10⁷,不会超时。

【完整代码】
def point(x, y):if x == y + 1 or x == y - 2:                  # x赢得分系数2return 2elif x == y:                                  # 平局得分系数1return 1else:                                         # x输不得分,得分系数0return 0n = int(input())
dp = [[-2000000000]*(n+1) for i in range(3)]      # 初始化为小于最高罚分:100*10⁶
a = [0]+[int(i) for i in input().split()]         # 数据索引从1开始
b = [0]+[int(i) for i in input().split()]         # 数据索引从1开始
c = [0]+[int(i) for i in input().split()]         # 数据索引从1开始
for j in range(3):dp[j][0] = point(j, c[1]) * a[1]              # 计算第1局出0、1、2得分
for i in range(2, n+1):for j in range(i-1, -1, -1):                  # 计算第2~n局出0、1、2得分for k in range(3):cur_score = point(k, c[i]) * a[i]dp[k][j] = dp[k][j] + cur_scoreif j > 0:for l in range(3):                # 计算换牌得分是否更高dp[k][j] = max(dp[k][j], dp[l][j-1] + cur_score - b[j])
ans = -2000000000                                 # 初始化为小于最高罚分:100*10⁶
for j in range(n):                                # 找最高分即为答案for k in range(3):ans = max(ans, dp[k][j])
print(ans)                                        # 输出答案
【运行结果】

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

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

相关文章

4.vue学习(21-25)

文章目录 21.天气案例-监视属性引入22.监视属性23.深度监视24 监视的简写25 监视属性对比计算属性 21.天气案例-监视属性引入 效果&#xff1a;点击按钮&#xff0c;切换凉爽为炎热 vscode 开发vue的插件;vue 3 snippets 初步实现方式。计算属性&#xff1a; 案例中的坑&#…

在Go语言中实现HTTP请求的缓存

大家好&#xff0c;我是你们可爱的编程小助手&#xff0c;今天我们要一起探讨如何使用Go语言实现HTTP请求的缓存。听起来是不是很酷&#xff1f;让我们开始吧&#xff01; 首先&#xff0c;我们要明白什么是缓存。简单来说&#xff0c;缓存就是将数据存储在内存中&#xff0c;…

基于SSM的网络游戏交易平台设计与实现

末尾获取源码 开发语言&#xff1a;Java Java开发工具&#xff1a;JDK1.8 后端框架&#xff1a;SSM 前端&#xff1a;Vue 数据库&#xff1a;MySQL5.7和Navicat管理工具结合 服务器&#xff1a;Tomcat8.5 开发软件&#xff1a;IDEA / Eclipse 是否Maven项目&#xff1a;是 目录…

多模态大模型Vary:扩充视觉Vocabulary,实现更细粒度的视觉感知

前言 现代大型视觉语言模型(LVLMs)具有相同的视觉词汇- CLIP&#xff0c;它可以涵盖大多数常见的视觉任务。然而&#xff0c;对于一些需要密集和细粒度视觉感知的特殊视觉任务&#xff0c;例如文档级OCR或图表理解&#xff0c;特别是在非英语场景下&#xff0c;clip风格的词汇…

内网穿透方案FRP内网穿透实战(基础版)

目录 前言方案 方案1&#xff1a;公网方案2&#xff1a;第三方内网穿透软件 花生壳cpolar方案3&#xff1a;云服务器做反向代理FRP简介FRP资源FRP原理FRP配置教程之SSH 前期准备服务器配置 下载FRP配置FRP服务端启动FRP服务端验证是否启动成功可能遇到的一些问题客户端配置 下…

融资项目——全局统一日志说明

通过日志可以查看程序的运行信息和异常信息等&#xff0c;便于维护。日志级别分为TRACE、DEBUG、INFO、WARN、ERROR级别&#xff0c;越往后打印的日志信息越少&#xff0c;如ERROR 级别只会在程序运行出错时才会打印日志。可在application.properties中设置日志级别。 logging…

Linux 进程和计划任务管理

一 内核功用&#xff1a;进程管理、内存管理、文件系统、网络功能、驱动程序、安全功能等 1 程序 是一组计算机能识别和执行的指令&#xff0c;运行于电子计算机上&#xff0c;满足人们某种需求的信息化工具 用于描述进程要完成的功能&#xff0c;是控制进程执行的指令集 2…

CentOS7搭建Elasticsearch与Kibana服务

1.部署单点es 1.1.创建网络 因为我们还需要部署kibana容器&#xff0c;因此需要让es和kibana容器互联。这里先创建一个网络&#xff1a; docker network create es-net 1.2拉取elasticsearch镜像 docker pull elasticsearch:7.11.1 1.3.运行 运行docker命令&#xff0c;部…

polar CTF 简单rce

一、题目 <?php /*PolarD&N CTF*/ highlight_file(__FILE__); function no($txt){if(!preg_match("/cat|more|less|head|tac|tail|nl|od|vim|uniq|system|proc_open|shell_exec|popen| /i", $txt)){return $txt;}else{ die("whats up");}} $yyds(…

Linux 485驱动通信异常

背景 前段时间接到一个项目&#xff0c;要求用主控用485和MCU通信。将代码调试好之后&#xff0c;验证没问题就发给测试了。测试测的也没问题。 但是&#xff0c;到设备量产时&#xff0c;发现有几台设备功能异常。将设备拿回来排查&#xff0c;发现是485通信有问题&#xff…

修复移动硬盘显示盘符但打不开问题

问题&#xff1a; 移动硬盘显示盘符&#xff0c;但无法打开。点击属性不显示磁盘使用信息。 分析解决&#xff1a; 这是由于硬盘存在损坏导致的&#xff0c;可以通过系统自带的磁盘检查修复解决&#xff0c;而无需额外工具。 假设损坏的盘符是E&#xff0c;在命令行运行以下命令…

5分钟理解什么是多模态

大家好&#xff0c;我是董董灿。 大模型越来越多了&#xff0c;大模型下沉的行业也越来越多。前几周一个在电厂工作的老哥发消息问我&#xff1a;大模型中所谓的多模态是什么意思&#xff1f; 我当时大概跟他解释了一下。 其实在人工智能领域&#xff0c;我们经常会听到&quo…