给定一个整型数组,在数组中找出由三个数组成的最大乘积,并输出这个乘积。
示例 1:
输入: [1,2,3]
输出: 6
示例 2:
输入: [1,2,3,4]
输出: 24
注意:
给定的整型数组长度范围是[3,104],数组中所有的元素范围是[-1000, 1000]。
输入的数组中任意三个数的乘积不会超出32位有符号整数的范围。
来源:力扣(LeetCode)
链接:https://leetcode-cn.com/problems/maximum-product-of-three-numbers
著作权归领扣网络所有。商业转载请联系官方授权,非商业转载请注明出处。
class Solution {
public:
long long max;
int maximumProduct(vector<int>& nums)
{
max = INT_MIN;
vector<vector<int>> ret;
vector<int> tmp;
vector<int> mynums;
sort(nums.begin(), nums.end());
if(nums.size() > 6)
{
mynums.push_back(nums[0]);
mynums.push_back(nums[1]);
mynums.push_back(nums[2]);
mynums.push_back(nums[nums.size() -3]);
mynums.push_back(nums[nums.size() -2]);
mynums.push_back(nums[nums.size() -1]);
backtrack(ret, tmp, mynums, 0);
}
else if(nums.size() <= 6)
backtrack(ret, tmp, nums, 0);
return max;
}
void backtrack(vector<vector<int>>& ret, vector<int> &tempList, vector<int>& nums, int start)
{
ret.push_back(tempList);
long long tmp = 1;
if(tempList.size() == 3)
{
tmp = tempList[0]*tempList[1]*tempList[2];
max = max > tmp ? max : tmp;
}
for(int i = start; i < nums.size(); i++)
{
tempList.push_back(nums[i]);
backtrack(ret, tempList, nums, i+1);
tempList.erase(tempList.begin() + tempList.size() - 1);
}
}
};