题解 | #三个数的最大乘积#

三个数的最大乘积

https://www.nowcoder.com/practice/8ae05c2913fe438b8b14f3968f64fc0b

#
# 代码中的类名、方法名、参数名已经指定,请勿修改,直接返回方法规定的值即可
#
# 最大乘积
# @param A int整型一维数组 
# @return long长整型
#
class Solution:
    def solve(self , A: List[int]) -> int:
        # write code here
        # 1.初始化2个空数组
        list1,list2=[],[]
        # 2.遍历A,如果为负数,放进数组list1,整数放进数组list2
        for i in A:
            if i<0:
                list1.append(i)
            if i>0:
                list2.append(i)
        # 3.数组list1和list2排序,并将list2逆序
        list1.sort()
        list2.sort()
        list2=list2[::-1]
        # 4.特殊情况1,如果2个负数乘积最大值大于2个整数乘积最大值,取(2个负数乘积最大值)去乘以整数最大值
        if len(list1)>=2 and len(list2)>=2 and (list1[0]*list1[1]>list2[0]*list2[1]):
            return max(list1[0]*list1[1],list2[0]*list2[1])*max(list2)
        # 5.特殊情况2,如果2个负数乘积最大值小于2个整数乘积最大值,但是2个负数乘积最大值再乘以整数最大值 会大于 三个整数乘积最大值。取(2个负数乘积最大值再乘以整数最大值
        elif len(list1)>=2 and len(list2)>=2 and (list1[0]*list1[1]<list2[0]*list2[1]) and (list1[0]*list1[1]*list2[0]>list2[0]*list2[1]*list2[2]):
            return list1[0]*list1[1]*list2[0]
        # 6.其他场景,数组A排序,返回数组A 前3个数或后3个数组 乘积最大值
        else:
            A.sort()
            return max(A[0]*A[1]*A[2],A[-1]*A[-2]*A[-3])
        

全部评论

相关推荐

书海为家:实习是成为大厂正式员工很好的敲门砖,看您的简历中有一段实习经历,挺好的。我来给一点点小建议,因为毕竟还在学校不像工作几年的老鸟有丰富的项目经验,面试官在面试在校生的时候更关注咱们同学的做事逻辑和思路,所以最好在简历中描述下自己实习时做过项目的完整过程,比如需求怎么来的,你对需求的解读,你想到的解决办法,遇到困难如何找人求助,最终项目做成了什么程度,你从中收获了哪些技能,你有什么感悟。
点赞 评论 收藏
分享
评论
点赞
收藏
分享

创作者周榜

更多
牛客网
牛客网在线编程
牛客网题解
牛客企业服务