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

简介: 从题意及示例可以知道,应该从大到小进行操作。当除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

相关文章
|
9天前
|
存储 监控 算法
关于员工上网监控系统中 PHP 关联数组算法的学术解析
在当代企业管理中,员工上网监控系统是维护信息安全和提升工作效率的关键工具。PHP 中的关联数组凭借其灵活的键值对存储方式,在记录员工网络活动、管理访问规则及分析上网行为等方面发挥重要作用。通过关联数组,系统能高效记录每位员工的上网历史,设定网站访问权限,并统计不同类型的网站访问频率,帮助企业洞察员工上网模式,发现潜在问题并采取相应管理措施,从而保障信息安全和提高工作效率。
30 7
|
1月前
|
存储 人工智能 算法
C 408—《数据结构》算法题基础篇—数组(通俗易懂)
408考研——《数据结构》算法题基础篇之数组。(408算法题的入门)
77 23
|
5月前
|
算法
Leetcode 初级算法 --- 数组篇
Leetcode 初级算法 --- 数组篇
65 0
|
5月前
|
算法 程序员 索引
数据结构与算法学习七:栈、数组模拟栈、单链表模拟栈、栈应用实例 实现 综合计算器
栈的基本概念、应用场景以及如何使用数组和单链表模拟栈,并展示了如何利用栈和中缀表达式实现一个综合计算器。
87 1
数据结构与算法学习七:栈、数组模拟栈、单链表模拟栈、栈应用实例 实现 综合计算器
|
5月前
|
存储 算法 定位技术
数据结构与算法学习二、稀疏数组与队列,数组模拟队列,模拟环形队列
这篇文章主要介绍了稀疏数组和队列的概念、应用实例以及如何使用数组模拟队列和环形队列的实现方法。
60 0
数据结构与算法学习二、稀疏数组与队列,数组模拟队列,模拟环形队列
|
7月前
|
存储 算法 Java
深入算法基础二分查找数组
文章深入学习了二分查找算法的基础,通过实战例子详细解释了算法的逻辑流程,强调了确定合法搜索边界的重要性,并提供了Java语言的代码实现。
深入算法基础二分查找数组
|
7月前
|
算法
【Azure Developer】完成算法第4版书中,第一节基础编码中的数组函数 histogrm()
【Azure Developer】完成算法第4版书中,第一节基础编码中的数组函数 histogrm()
|
7月前
|
算法
【算法】模拟算法——外观数组(medium)
【算法】模拟算法——外观数组(medium)
|
7月前
|
算法
【算法】前缀和——除自身以外数组的乘积
【算法】前缀和——除自身以外数组的乘积
|
7月前
|
算法
【算法】前缀和——寻找数组的中心下标
【算法】前缀和——寻找数组的中心下标

热门文章

最新文章