拼多多算法工程师笔试题之求解一维无序数组中三个数字乘积最大值(正负零均存在)

320 篇文章 88 订阅
151 篇文章 4 订阅

题目:

给定一个包含正负数和零的一维无序数组,找到三个数字使得乘积最大

思路:

这道题目是个坑啊,我上来都没看直接当做之前一篇博文中求解矩阵中最大子数组和的问题了,采用动态规划的思想来解决,结果呢,只通过了10%左右,感觉很不可思议,于是重新读题发现不对了,人家说的是三个数字的乘积我这里动态规划的是两个数字的乘积,改成了三个数字的乘积也不对,瞬间郁闷了,不知道问题出现在了哪里,就只好自己在草稿纸上瞎写了,突然发现了端倪,题目给的样例也是一个坑,负数在这里是一个很关键的东西,因为:负负得正啊,那么接下来思路就有了,很简单,先对无序数组排序,那么所有的非负数肯定是出现在了数组的右端(这里默认是升序),在最左端的数可能是0,也可能是正数,也可能是负数,这里分几种情况考虑如下:

1.最左端是0,那么数组中不存在负数,最大值计算为:num_list[-1]*num_list[-2]*num_list[-3]

2.最左端为正数:同上

3.最左端为负数,这里可能有人会说需要考虑负数的个数,其实仔细想想是不需要,这里直接把左端的最大值记为:num_list[0]*num_list[1]*num_list[-1],是不是看出来什么端倪了,对,就是这意思,如果有超过两个负数那么这个表达式计算出来的结果必定是正数而且可能是最大值,如果只有一个负数,那么出现的结果就是:这个表达式的值必然为负数,那么最大值的计算结果就同上面两种情况了

    有了上面的分析之后,就可以得到下面几行代码的实现了,当然核心真的只有四五行,我下面加入了一点打印信息方便看结果:


#!usr/bin/env python  
#encoding:utf-8  
  
''''' 
__Author__:沂水寒城 
功能:求解一维无序数组中三个数字乘积最大值(正负零均存在)
''' 


def LargetThreeNumMutiple(n, num_list):
    num_list = [ int(i) for i in num_list.split(' ') ]
    num_list.sort()
    return max(num_list[0] * num_list[1] * num_list[-1], num_list[-1] * num_list[-2] * num_list[-3])

if __name__ == '__main__':
    n = raw_input()
    num_list = raw_input()
    print '三个数字乘积最大值为:', LargetThreeNumMutiple(n, num_list)




结果如下:


4
4 3 2 1
三个数字乘积最大值为: 24

7
0 9 -5 7 1 3 2
三个数字乘积最大值为: 189

5
0 1 6 11 4
三个数字乘积最大值为: 264

10
-3 -5 -7 -11 -9 0 3 5 67 1
三个数字乘积最大值为: 6633

15
-34 23 45 6 7 0 0 -12 -32 -45 90 44 55 90 -100
三个数字乘积最大值为: 445500

    好了,要回去睡觉了,好困,如有感兴趣的朋友,欢迎交流哈。

评论 11
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

Together_CZ

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值