算法笔试模拟题精解之“调整数组”

简介: 首先理解题意:经过k次操作后能出现次数最多的元素, 以及这个元素的最小值;然后将示例仔细分析一下,就可以找到解题的方法了。

在线编程介绍

阿里云开发者社区在线编程产品,针对广大开发者学习、实践、面试、应聘、考试认证等打造的免费在线刷题神器。题库来自笔试模拟题、算法大赛模拟题等,界面整洁明了,操作简单,为用户营造专心答题的学习环境。点击链接开始体验:https://developer.aliyun.com/coding

本文为大家介绍其中的 第89题:调整数组 的题目解析,具体如下:

题目描述

等级:中等
知识点:尺取法

查看题目:调整数组
A同学有一个长度为n的数组,对于这个数组,他能够进行k次如下操作:任选数组中的某个元素将其数值加一(一个元素可以被加多次)。
他想在操作不超过k次的情况下,使得数组中某一元素的出现次数尽可能的多,并同时使这个元素尽可能的小。
请你找出出现次数最多的元素的出现次数以及此时这个元素的最小值。

输入:
输入数组长度n(1 <= n <= 10^5),最多能操作次数k(1 <= k <= 10^5),和一个包含n个数的数组,数组中第i个元素的值为ai(0 <= ai <= 10^4)。

输出:
输出操作后出现次数最多的元素的出现次数以及此时这个元素的最小值。

解题方法:模拟法

变量概述

  • int n : 有n个数
  • int k : 最多操作k次
  • int[] a : 存储n个数的数组
  • 只能对a[i]进行一种操作 : +1

首先理解题意:经过k次操作后能出现次数最多的元素, 以及这个元素的最小值;
示例说明:

  • 1 2 2 3 3 4

两个3要变成4就得操作2次
两个2要变成4就得操作4次

  • 因为 ai 的大小被限定在[0, 10^4], 所以可以使用一个数组arr, 来统计每个数字出现的次数。
  • 遍历数组arr, 对于任意不等于0的数arr[i], 逆向遍历前面所有*不为0的***arr[j]**, 并对每个不为0的arr[j], **k-=arr[j] * (i-j)**, 直到k不够减或没前面没数字了。
  • 如果是k不够减, 则得在判断k能够再减去多少个arr[j], 因为之前的公式是计算减去所有的arr[j]的
  • 之所以要不为0的, 是因为压根没有这个数, 无法对其进行+操作

解题步骤

1、定义变量

  • int[] arr : 用来存储每个数字出现的次数, 容量为10001
  • int max : 用来存储最大次数, 初始化为1
  • int maxValue : 用来存储最大次数所对应的最小值, 随着最大次数的更新而更新, 初始化为a[0]
  • int k1 : 用来备份k值, 避免k值计算后不见了
  • int temp : 用来统计当前最大数字出现的次数, 初始化为arr[i]

2、遍历数组arr, 找出出现最多的次数以及对应的最小值.

  • 对于每个arr[j] 如果arr[j]为0, 则直接跳过. 不是不加,而是没法加
  • 如果arr[j] * (i-j) <= k, 证明当前的操作次数能够将j全部变成i, 则使用temp加上所有的j
  • 如果arr[j] * (i-j) > k, 则证明当前次数k无法将全部j变成i,开始尝试将部分j转成i

    • 使用k/(i-j)计算还能够将多少个j转成i,然后进行转换
    • 判断temp和最大值是否大于最大次数max, 如果大于, 则更新max和maxValue
  • 注意: 当arr[j]顺利遍历到arr[0]时退出循环, 因为我们的比较最大值操作是在循环内进行的, 所以此时, 可能无法对max进行更新, 因此需要在手动判断一次temp和max的大小

3、返回数组

时间复杂度: O(n^2)
空间复杂度: O(n)

看完之后是不是有了想法了呢,快来练练手吧>>查看题目:调整数组

720-150.png

相关文章
|
1月前
|
存储 人工智能 算法
C 408—《数据结构》算法题基础篇—数组(通俗易懂)
408考研——《数据结构》算法题基础篇之数组。(408算法题的入门)
72 23
|
5月前
|
算法
Leetcode 初级算法 --- 数组篇
Leetcode 初级算法 --- 数组篇
62 0
|
5月前
|
算法 程序员 索引
数据结构与算法学习七:栈、数组模拟栈、单链表模拟栈、栈应用实例 实现 综合计算器
栈的基本概念、应用场景以及如何使用数组和单链表模拟栈,并展示了如何利用栈和中缀表达式实现一个综合计算器。
81 1
数据结构与算法学习七:栈、数组模拟栈、单链表模拟栈、栈应用实例 实现 综合计算器
|
5月前
|
存储 算法 定位技术
数据结构与算法学习二、稀疏数组与队列,数组模拟队列,模拟环形队列
这篇文章主要介绍了稀疏数组和队列的概念、应用实例以及如何使用数组模拟队列和环形队列的实现方法。
54 0
数据结构与算法学习二、稀疏数组与队列,数组模拟队列,模拟环形队列
|
7月前
|
算法
【Azure Developer】完成算法第4版书中,第一节基础编码中的数组函数 histogrm()
【Azure Developer】完成算法第4版书中,第一节基础编码中的数组函数 histogrm()
|
7天前
|
机器学习/深度学习 算法 数据安全/隐私保护
基于GRU网络的MQAM调制信号检测算法matlab仿真,对比LSTM
本研究基于MATLAB 2022a,使用GRU网络对QAM调制信号进行检测。QAM是一种高效调制技术,广泛应用于现代通信系统。传统方法在复杂环境下性能下降,而GRU通过门控机制有效提取时间序列特征,实现16QAM、32QAM、64QAM、128QAM的准确检测。仿真结果显示,GRU在低SNR下表现优异,且训练速度快,参数少。核心程序包括模型预测、误检率和漏检率计算,并绘制准确率图。
80 65
基于GRU网络的MQAM调制信号检测算法matlab仿真,对比LSTM
|
12天前
|
算法
基于遗传优化算法的风力机位置布局matlab仿真
本项目基于遗传优化算法(GA)进行风力机位置布局的MATLAB仿真,旨在最大化风场发电效率。使用MATLAB2022A版本运行,核心代码通过迭代选择、交叉、变异等操作优化风力机布局。输出包括优化收敛曲线和最佳布局图。遗传算法模拟生物进化机制,通过初始化、选择、交叉、变异和精英保留等步骤,在复杂约束条件下找到最优布局方案,提升风场整体能源产出效率。
|
12天前
|
算法 安全 机器人
基于包围盒的机械臂防碰撞算法matlab仿真
基于包围盒的机械臂防碰撞算法通过构建包围盒来近似表示机械臂及其环境中各实体的空间占用,检测包围盒是否相交以预判并规避潜在碰撞风险。该算法适用于复杂结构对象,通过细分目标对象并逐级检测,确保操作安全。系统采用MATLAB2022a开发,仿真结果显示其有效性。此技术广泛应用于机器人运动规划与控制领域,确保机器人在复杂环境中的安全作业。
|
12天前
|
机器学习/深度学习 数据采集 算法
基于WOA鲸鱼优化的CNN-GRU-SAM网络时间序列回归预测算法matlab仿真
本项目基于MATLAB 2022a实现时间序列预测,采用CNN-GRU-SAM网络结构,结合鲸鱼优化算法(WOA)优化网络参数。核心代码含操作视频,运行效果无水印。算法通过卷积层提取局部特征,GRU层处理长期依赖,自注意力机制捕捉全局特征,全连接层整合输出。数据预处理后,使用WOA迭代优化,最终输出最优预测结果。
|
6天前
|
机器学习/深度学习 算法 数据安全/隐私保护
基于机器学习的人脸识别算法matlab仿真,对比GRNN,PNN,DNN以及BP四种网络
本项目展示了人脸识别算法的运行效果(无水印),基于MATLAB2022A开发。核心程序包含详细中文注释及操作视频。理论部分介绍了广义回归神经网络(GRNN)、概率神经网络(PNN)、深度神经网络(DNN)和反向传播(BP)神经网络在人脸识别中的应用,涵盖各算法的结构特点与性能比较。