算法笔试模拟题精解之“全奇数组”

简介: 从题意及示例可以知道,应该从大到小进行操作。当除2后,需要快速查找是否有相等的其他数,这个需求可以使用HashSet代替。

在线编程介绍

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

本文为大家介绍其中的第62题:全奇数组 的题目解析,具体如下:

题目描述

题目等级:中等
知识点:堆、贪心、哈希
查看题目:全奇数组 codancer现在有n个正整数a[1],a[2]…a[n],Tom告诉codancer他可以进行下列操作,选择某个偶数x,把这n个数中全部等于x的数字除2,Tom想知道把这n个数字全部变成奇数最少需要几次这样的操作?

输入一个正整数n(1<=n<=100000),代表有n个正整数,接下来输入这n个正整数。

输出codancer把这n个数字全部变成奇数的最少次数。

示例1
输入:
6
[40,6,40,3,20,1]
输出:
4
注意
1.x=40,数组变为
[20,6,20,3,20,1]
2.x=20,数组变为
[10,6,10,3,10,1]
3.x=10,数组变为
[5,6,5,3,5,1]
4.x=6,数组变为
[5,3,5,3,5,1]
因此最少需要4次

解题思路

从题意及示例可以知道,应该从大到小进行操作。当除2后,需要快速查找是否有相等的其他数,这个需求可以使用HashSet代替。

因此,先将n个中的偶数入HashSet,再对HashSet中元素从大到小排序,依次遍历;

每个元素除2后从HashSet查找,存在则移除,计数+1,直到该数变成奇数。

最坏情况下,除2过程没有重复数字
时间复杂度:O(n+n*n/2)
空间复杂度:O(n)

看完之后是不是有了想法了呢,题目直达链接:查看题目:全奇数组
720-150.png

相关文章
|
1月前
|
算法
Leetcode 初级算法 --- 数组篇
Leetcode 初级算法 --- 数组篇
38 0
|
3月前
|
算法 测试技术
【算法】二分算法——寻找旋转排序数组中的最小值
【算法】二分算法——寻找旋转排序数组中的最小值
|
3月前
|
算法
【算法】二分查找——在排序数组中查找元素的第一个和最后一个位置
【算法】二分查找——在排序数组中查找元素的第一个和最后一个位置
|
1月前
|
算法 程序员 索引
数据结构与算法学习七:栈、数组模拟栈、单链表模拟栈、栈应用实例 实现 综合计算器
栈的基本概念、应用场景以及如何使用数组和单链表模拟栈,并展示了如何利用栈和中缀表达式实现一个综合计算器。
31 1
数据结构与算法学习七:栈、数组模拟栈、单链表模拟栈、栈应用实例 实现 综合计算器
|
1月前
|
存储 算法 定位技术
数据结构与算法学习二、稀疏数组与队列,数组模拟队列,模拟环形队列
这篇文章主要介绍了稀疏数组和队列的概念、应用实例以及如何使用数组模拟队列和环形队列的实现方法。
21 0
数据结构与算法学习二、稀疏数组与队列,数组模拟队列,模拟环形队列
|
3月前
|
存储 算法 Java
深入算法基础二分查找数组
文章深入学习了二分查找算法的基础,通过实战例子详细解释了算法的逻辑流程,强调了确定合法搜索边界的重要性,并提供了Java语言的代码实现。
深入算法基础二分查找数组
|
3月前
|
算法
【Azure Developer】完成算法第4版书中,第一节基础编码中的数组函数 histogrm()
【Azure Developer】完成算法第4版书中,第一节基础编码中的数组函数 histogrm()
|
3月前
|
算法
【算法】模拟算法——外观数组(medium)
【算法】模拟算法——外观数组(medium)
|
3月前
|
算法
【算法】前缀和——除自身以外数组的乘积
【算法】前缀和——除自身以外数组的乘积
|
3月前
|
算法
【算法】前缀和——寻找数组的中心下标
【算法】前缀和——寻找数组的中心下标
下一篇
无影云桌面