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.mzph.cn/news/594325.shtml

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

相关文章

微信公众号请求获取相关权限后端代码

用微信的东西&#xff0c;总要避免到各种与微信那边的交互。 1.首先要有个接口&#xff0c;证明你是服务端&#xff08;填写服务器配置&#xff09; 接入概述 | 微信开放文档 主代码 /*** 服务器配置验证* param* return*/PassTokenGetMapping("/giveWxCheck")publi…

详解Vue3中的事件监听方式

本文主要介绍Vue3中的事件监听方式。 目录 一、v-on指令二、使用符号简写三、事件修饰符四、动态事件名五、常见的监听事件六、自定义事件 在Vue3中&#xff0c;事件监听的方式与Vue2有一些不同。 下面是Vue3中事件监听方式的详细介绍&#xff1a; 一、v-on指令 Vue3中仍然使…

​LeetCode解法汇总2487. 从链表中移除节点

目录链接&#xff1a; 力扣编程题-解法汇总_分享记录-CSDN博客 GitHub同步刷题项目&#xff1a; https://github.com/September26/java-algorithms 原题链接&#xff1a; 力扣&#xff08;LeetCode&#xff09;官网 - 全球极客挚爱的技术成长平台 描述&#xff1a; 给你一个…

WPF容器的背景对鼠标事件的影响

背景&#xff1a;在实现鼠标拖动窗口的过程中发现对父容器设置了鼠标拖动窗口的事件MouseLeftButtonDown private void DragWindow(object sender, MouseButtonEventArgs e) {if (e.LeftButton MouseButtonState.Pressed)DragMove(); } 问题&#xff1a;非常困惑的是&#x…

C# windows服务程序开机自启动exe程序

我们使用传统的Process.Start(".exe")启动进程会遇到无法打开UI界面的问题&#xff0c;尤其是我们需要进行开启自启动程序设置时出现诸多问题&#xff0c;于是我们就想到采用windows服务开机自启动来创建启动一个新的exe程序&#xff0c;并且是显式运行。 首先是打开…

软件测试入门(知识汇总)

1、黑盒测试、白盒测试、灰盒测试 1.1 黑盒测试 黑盒测试又叫功能测试、数据驱动测试 或 基于需求规格说明书的功能测试。该类测试注重于测试软件的功能性需求。 采用这种测试方法&#xff0c;测试工程师把测试对象看作一个黑盒子&#xff0c;完全不考虑程序内部的逻辑结构和…

clickhouseSQL日期相关

1. 毫秒级时间戳转日期/小时 --13位时间戳转具体时间 toDateTime(report_time / 1000) as _c00 -- 获取时间戳对应的时间点整点(结果&#xff1a;%Y-%m-%d %H:00:00.0) eg&#xff1a;2022-09-28 23:00:00.0 toStartOfHour(toDateTime(report_time / 1000)) AS _10-- 获取时间…

Rust使用gRPC

需要先安装protoc&#xff08;Protocol Buffers Compiler&#xff09;&#xff0c;可据此Protobuf Compiler Installation下载 第一步&#xff1a;创建项目 创建两个新的Rust项目&#xff0c;分别作为服务端与客户端&#xff1a; cargo new rust_grpc_servercargo new rust_grp…

【操作系统习题】处理机调度与死锁

一、单选题 FCFS算法的就绪队列是按照进程的&#xff08;&#xff09;排列。 B A、等待时间 B、到达时间 C、响应时间 D、运行时间设有4个作业同时到达&#xff0c;每个作业的执行时间均为2个小时&#xff0c;它们在一台处理机上按单道方式执行&#xff0c;则平均周转时间为&a…

PAT 乙级 1042 字符统计

请编写程序&#xff0c;找出一段给定文字中出现最频繁的那个英文字母。 输入格式&#xff1a; 输入在一行中给出一个长度不超过 1000 的字符串。字符串由 ASCII 码表中任意可见字符及空格组成&#xff0c;至少包含 1 个英文字母&#xff0c;以回车结束&#xff08;回车不算在内…

Winform中使用Fleck实现Websocket服务端并读取SQLite数据库中数据定时循环群发消息

场景 Winform中使用Websocket4Net实现Websocket客户端并定时存储接收数据到SQLite中&#xff1a; Winform中使用Websocket4Net实现Websocket客户端并定时存储接收数据到SQLite中-CSDN博客 Winform中操作Sqlite数据增删改查、程序启动时执行创建表初始化操作&#xff1a; Wi…

Vue3 结合typescript 组合式函数(2)

安装axios&#xff1a;npm install axios 1、hooks文件夹下新建useURLLoader 在APP.VUE中使用useURLLoader 使用Dog API 2、使用对象中的属性&#xff0c;必须使用toRefs&#xff0c;否则Reactive响应失效 3、使用泛型 结果&#xff1a;

C++不懂就问:std::vector的push_back和emplace_back函数的差别?

欢迎关注公众号(20YC编程)&#xff0c;视频号也有免费视频课程哦&#xff01; -今日内容- 1 emplace_back介绍 std::vector的emplace_back&#xff08;包括emplace&#xff09;函数是C11引入的新特性&#xff0c;用于在容器中直接构造元素&#xff0c;而不是先构造元素再插入…

3 - 字段约束|MySQL索引|MySQL用户管理

字段约束&#xff5c;MySQL索引&#xff5c;MySQL用户管理 字段约束主键外键 MySQL索引索引介绍优缺点索引使用规则索引的分类索引的管理 用户管理用户授权权限撤销 用户权限追加user表的使用 字段约束 设置在表头上&#xff0c;用来限制字段赋值 包括&#xff1a; 是否允许给…

基于深度学习的交通标志图像分类识别系统

温馨提示&#xff1a;文末有 CSDN 平台官方提供的学长 QQ 名片 :) 1. 项目简介 本文详细探讨了一基于深度学习的交通标志图像识别系统。采用TensorFlow和Keras框架&#xff0c;利用卷积神经网络&#xff08;CNN&#xff09;进行模型训练和预测&#xff0c;并引入VGG16迁移学习…

MySQL基础学习: 由delete和insert操作导致的死锁问题

一、问题复现&#xff1a;表结构 CREATE TABLE user_props (user_id bigint NOT NULL ,prop_key varchar(100) NOT NULL ,prop_value varchar(100) NOT NULL,PRIMARY KEY (user_id,prop_key) )二、死锁测试 &#xff08;1&#xff09;开启两个事务 &#xff08;2&#xff09;…

QGIS设计导出Geoserver服务使用的SLD样式

1、打开QGis软件 2、打开shp文件所在所在文件夹&#xff0c;双击添加选中图层 3、编辑shp文件样式 &#xff08;1&#xff09;双击“Layers”中需要编辑的图层 &#xff08;2&#xff09;选择样式 &#xff08;3&#xff09;编辑样式后&#xff0c;选择“应用”—》“确定” 4…

安装MYsql5.7和8.0以及区别

MySQL5.7的安装步骤 解压 将my.ini文件拷贝到解压的目录下 更改my.ini文件&#xff0c;将安装目录替换&#xff0c;并将\改成\\ 在bin目录下进入cmd 执行安装&#xff1a; mysqld install 失败可能是应为没有用管理员身份执行cmd&#xff0c;要在开始菜单进入cmd &#xff…

【致远FAQ】V8.0sp1_门户设置——页面组件中设置列表头的颜色

问题描述 门户设置——页面组件中设置列表头的颜色后&#xff0c;底表数据查看时的列表头颜色没有变呢 解决办法 设置不对cap4生效&#xff0c;只针对原始oa的列表支持&#xff08;比如协同工作——已办事项、公文等列表项&#xff09; 设置参考

深度学习|2.4 梯度下降

如上图&#xff0c; J ( w , b ) J(w,b) J(w,b)是由w和b两个参数共同控制的损失函数&#xff0c;损失是不好的东西&#xff0c;所以应该求取合适的w和b使得损失最小化。 为了简单考虑&#xff0c;可以先忽略参数b。 斜率可以理解成在朝着x正方向移动单位距离所形成的损失值的变…