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

0518蚂蚁暑期实习上机考试题1:数组操作

题目

小红认为一个长度为 n 的数组 a 是好的,当且仅当对于任意的 i ,均满足\left | a_i-i \right |相等,其中数组下标 i 从 1 开始,小红每次可以对一个数加 1 或者减 1 ,求把给定的数组变成好数组的最少操作次数。

输入描述:第一行是一个整数n\left ( 1\leq n\leq 1000 \right ),表示数组长度。 第二行是n个整数,第i个为a_i\left ( 1\leq a_i\leq n \right )

输出描述:一个整数,表示把给定的数组变成好数组的最少操作次数。

输入示例1:

3
3 2 1

输出示例1:

2

解释:

将数组[3,2,1]调整为[3,4,1]经过的步数最小,为2;[3,4,1]是一个好数组,满足:

\left | 3-1 \right |=\left | 4-2 \right |=\left | 1-3 \right |=2

输入示例2:

3
1 2 3

输出示例2:

0

解答

此题注意输入的第二句话:数组是n个整数,第i个数组元素为a_i\left ( 1\leq a_i\leq n \right )

我们很容易设对于任意的 i ,都满足\left | a_i-i \right |=k。对于给定的ka_i需要调整到i+k或者i-k。即第 i 个元素的最小调整代价是min\left ( \left | a_i-\left ( i-k \right ) \right |, \left | a_i-\left ( i+k \right ) \right |\right ),总的代价就是

cost=\sum_{i=1}^{n}min\left ( \left | a_i-\left ( i-k \right ) \right |, \left | a_i-\left ( i+k \right ) \right |\right )

因此,只需从0遍历k,得到最小代价时的k,然后返回这个最小代价即可。

那么k的上界应该取多少呢?注意到:

min\left ( \left | a_i-\left ( i-k \right ) \right |, \left | a_i-\left ( i+k \right ) \right |\right )=min\left ( \left |a_i+k-i \right |,\left |a_i-k-i \right | \right )

k\geq n时,可以去掉绝对值:

min\left ( \left |a_i+k-i \right |,\left |a_i-k-i \right | \right )=min\left ( a_i+k-i,k+i-a_i \right )\left ( k\geq n \right )

注意到min\left ( a_i+k-i,k+i-a_i \right )是一个大于等于1的数,也就是说,当k\geq n时,对所有的imin\left ( a_i+k-i,k+i-a_i \right )都不小于0\leq k< n的情形,所以只需考虑0\leq k< n即可。

代码实现:

import sysdef solve():# data = sys.stdin.read().split()# n = int(data[0])# a = list(map(int, data[1:]))n = 10a = [9, 2, 3, 1, 5, 8, 6, 2, 4, 7]ans = float('inf')# 枚举可能的 k 值for k in range(n):total = 0# 对每个位置计算最小操作次数for i in range(1, n + 1):# 直接计算变为 i+k 与 i-k 的代价c1 = abs(a[i - 1] - (i + k))c2 = abs(a[i - 1] - (i - k))total += min(c1, c2)ans = min(ans, total)print(ans)if __name__ == '__main__':solve()
http://www.lqws.cn/news/103591.html

相关文章:

  • go get下载三方库异常
  • STM32入门教程——按键控制LED光敏传感器控制蜂鸣器
  • Leetcode 261. 以图判树
  • ​链表题解——回文链表【LeetCode】
  • Java基础 Day28 完结篇
  • 使用 Golang `testing/quick` 包进行高效随机测试的实战指南
  • Elasticsearch集群最大分片数设置详解:从问题到解决方案
  • Mac电脑_钥匙串操作选项变灰的情况下如何删除?
  • React-native之Flexbox
  • 相机Camera日志分析之二十四:高通相机Camx 基于预览1帧的process_capture_request三级日志分析详解
  • torch.distributed.launch 、 torchrun 和 torch.distributed.run 无法与 nohup 兼容
  • Redis:常用数据结构 单线程模型
  • 【Typst】3.Typst脚本语法
  • 使用Redis作为缓存优化ElasticSearch读写性能
  • AutoGenTestCase - 借助AI大模型生成测试用例
  • 批量大数据并发处理中的内存安全与高效调度设计(以Qt为例)
  • 基于Matlab实现LDA算法
  • MySQL 全量、增量备份与恢复
  • 医疗内窥镜影像工作站技术方案(续)——EFISH-SCB-RK3588国产化替代技术深化解析
  • Linux 命令全讲解:从基础操作到高级运维的实战指南
  • Python实例题:Flask实现简单聊天室
  • SIFT 算法原理详解
  • 户外摄像头监控如何兼顾安全实时监控
  • 深度学习与特征交叉:揭秘FNN与SNN在点击率预测中的应用
  • 电工基础【4】点动接线实操
  • 【电力电子】什么是并网?为什么要并网?并网需要考虑哪些因素?
  • matlab实现求解兰伯特问题
  • 华为OD机试_2025 B卷_精准核酸检测(Python,100分)(附详细解题思路)
  • 相机camera开发之差异对比核查一:测试机和对比机的硬件配置差异对比
  • Linux随记(十八)