zoukankan      html  css  js  c++  java
  • 求解列表中三个数的最大乘积

    三种情况:1)全部为正数;2)全部为负数;3)有负有正。对传入数据排序:

    如果排序后的数组的最大元素为负数,则说明数组元素均为负数
    如果排序后的数组的最大元素为正数,则又需要分情况讨论:
    数组中所有元素均为正数,则最大值为最后三个数组元素的乘积;
    数组中元素有正数,也有负数;这时候就需要进行比较了;用最后三个数组元素的乘积与最大元素和数组中前两个元素乘积进行比较,取其中较大的值。

    def max_product(li):
        # method 1
        # li.sort()
        # return max(li[-1] * li[-2] * li[-3], li[0] * li[1] * li[-1])
        # method 2
        min_1, min_2 = float("inf"), float("inf")
        max_1, max_2, max_3 = float("-inf"), float("-inf"), float("-inf")
        for i in li:
            if i < min_1:
                min_2 = min_1
                min_1 = i
            elif i < min_2:
                min_2 = i
            if i > max_1:
                max_3 = max_2
                max_2 = max_1
                max_1 = i
            elif i > max_2:
                max_3 = max_2
                max_2 = i
            elif i > max_3:
                max_3 = i
    
        return max(max_1*max_2*max_3, min_1*min_2*max_1)
    
    if __name__ == '__main__':
        print(max_product([1,2,3,4,5,6]))
    时刻记着自己要成为什么样的人!
  • 相关阅读:
    [BJOI2006]狼抓兔子
    [HNOI2016]最小公倍数
    hihocoder 1419 重复旋律4
    [NOI2015]品酒大会
    [SDOI2016]生成魔咒
    [ZJOI2009]狼和羊的故事
    BZOJ4361 isn
    [SDOI2009]虔诚的墓主人
    BZOJ 3329 Xorequ
    [ZJOI2013]丽洁体
  • 原文地址:https://www.cnblogs.com/demo-deng/p/14698636.html
Copyright © 2011-2022 走看看