图解一道今日头条面试算法题

本文分享了一道今日头条的算法面试题,要求在有序数组中求平方后不同值的数量。通过逐步分析,提出了从简单解法到优化算法的过程,最终实现了空间复杂度为O(1)的解决方案,主要利用了数组有序和双指针策略。
摘要由CSDN通过智能技术生成

前几天听同事分享了一道今日头条的算法面试题,感觉非常有趣,今天也分享给大家,题目是这样的:

给定一个有序数组,数组中有正数、负数或者0,对数组中所有的数求平方后问有多少个不同的值。

比如对于数组[-1,0,1,1,1,1],对数组求平方后为[1,0,1,1,1,1],那么最终的结果是2,因为最后只有0和1两个不同的数;

对于数组[-1,0,1,2,3],对数组求平方后为[1,0,1,4,9],那么最终的结果是4,因为最后数组中为0,1,4,9这四个不同的数;

同事提到只有时间复杂度为O(n),空间复杂度为O(1)的算法才能通过面试,在听到这个题目后首先想的就是如果在面试中自己遇到这个题目该如何解决?

我是如何思考的

如果在面试中遇到这个题目我会先给出一个最简单的解法,也就是直接对数组中的每一个数字求平方,然后放到map中,最后求一下map的大小就可以了,整个过程如图所示:

实际上这种解法有个问题,那就是对数字求平方和容易导致溢出,而实际上我们根本就无需求平方,实际上只需要求出绝对值就可以了,只要两个数字的绝对值相等,那么这两个数字的平方也一定相等。因此我们只需要将上图中的第一步由求平方改为求绝对值就可以了。

这个算法相对简单,也很容易想到,实际复杂度为O(n)满足要求,但是由于我们使用了map,因此空间复杂度为O(n),不能满足面试要求的O(1),那么该如何改进呢?

在往下看之前你要首先自己想一想该如何改进。

优化算法:利用数组有序

不要忘了题目给定的是一个有序数组,上图中的算法没有利用到这一性质。

我的想法是这样的,给定一个有序数组,如果这个数组中没有负数,那么这个题目是极其简单的,因为在一个有序数组中相同的数组一定是相邻的

比如对于数组[0,1,1,1,1],其中四个1是相邻的,我们只需要在遍历数组的时候不计入重复的数字就可以了。

但是现在问题的关键在于数组中还有负数,对于负数该如何处理呢?很简单,我们只需要将负数部分转为正数就可以了,这样我们就得到了两个子数组,这两个子数组都是有序的,然后将这两个有序子数组原地合并,这样就得到了一个不包含负数的有序数组,问题圆满解决,如图所示:

问题

看上去看正确有没有,没有额外使用空间,而且时间复杂

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值