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

华为OD-2024年E卷-找终点[100分] -- python

问题描述:

给定一个正整数数组,设为nums,最大为100个成员,求从第一个成员开始,正好走到数组最后一个成员,所使用的最少步骤数。要求:

  1. 第一步必须从第一元素开始,且1<=第一步的步长<len/2;(len为数组的长度,需要自行解析)。
  2. 从第二步开始,只能以所在成员的数字走相应的步数,不能多也不能少,如果目标不可达返回-1,只输出最少的步骤数量。
  3. 只能向数组的尾部走,不能往回走。

输入描述
由正整数组成的数组,以空格分隔,
数组长度
小于100,请自行解析数据数量。
输出描述
正整数,表示最少的步数,如果不存在输出-1
示例1
输入

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

输出

2

说明
第一步:第一个可选步长选择2,从第一个成员7开始走2步,到达9;第二步:从9开始,经过自身数字9对应的9个成员到最后。

解题思路:

列表模拟:

  1. 遍历前n/2个元素
  2. 对每个元素,下一跳索引 [i+1] = 索引 [i] + 值 [i]
  3. 判断是否能刚好到达最后一个元素

循环条件:

  1. 若当前索引 = 数组长度 - 1,则将当前步数加入ans列表
  2. 若当前索引 > 数组长度 - 1,则跳出循环
  3. 否则继续下一跳

代码实现:

arr = list(map(int,input().split()))
n = len(arr)
s = int(n/2)
ans = []
for index in range(s):step = 1#记录次数while index < n:index += arr[index]if index >= n:breakelif index == n-1:ans.append(step+1)step += 1
if len(ans) != 0:ans.sort()print(ans[0])
else:print(-1)

相关文章:

  • Anaconda 安装教程(Windows/macOS/Linux)
  • 数字孪生技术助力:UI前端设计的精准度与效率双提升
  • STM32L431中,低功耗模式下的仿真调试功能受到限制
  • 解锁AI密码:全面赋能海外社媒矩阵运营
  • 【2023 - 2025 年】6大PLM系统主要干活,提升项目管理效率
  • SEO 与性能优化说明文档
  • Leap Micro不可变Linux
  • USB接口DP(D-)和DM(D+)英文全称
  • EMAGE:通过具表现力的掩码音频动作建模,实现统一的整体共语姿态生成
  • 设置Git和Github
  • 【Python打卡Day44】预训练模型 @浙大疏锦行
  • ACM设计平台-核心模块解析-赵家康
  • Python实现高效导入Excel数据到ClickHouse
  • ImageNet 上的安全外包神经网络推理
  • HarmonyOS5 购物商城app(二):购物车与支付(附代码)
  • 使用DevEco Testing快速创建HarmonyOS5单元测试
  • 从源码角度了解Elasticsaerch(分布式协调排序、深分页问题)
  • 【Java】脱离 JVM 约束 GraalVM + Liberica NIK + Spring + Docker 将 Java 编译为平台二进制可执行文件
  • 亚马逊深度整合全食超市,重塑全球跨境电商与生鲜零售格局
  • FPGA基础 -- Verilog语言要素之值集合
  • 菜谱网站后台代码/磁力引擎
  • 广东省城乡建设厅投诉网站/二手交易平台
  • 做企业网站都有什么平台/免费seo网站诊断免费
  • 哪里找做网站的客户/搜资源的搜索引擎
  • php做网站首页/百度数字人内部运营心法曝光
  • 富连网网站开发/深圳seo