Giả sử chúng ta có một mảng số nguyên; chúng ta phải tìm ba số có sản phẩm là tối đa sau đó trả về sản phẩm tối đa.
Vì vậy, nếu đầu vào là [1,1,2,3,3], thì đầu ra sẽ là 18, vì ba phần tử là [2,3,3].
Để giải quyết vấn đề này, chúng tôi sẽ làm theo các bước sau -
-
sắp xếp số mảng
-
l:=kích thước của nums
-
a:=nums [l - 1], b:=nums [l - 2], c:=nums [l - 3], d:=nums [0], e:=nums [1]
-
trả về tối đa a * b * c và d * e * a
Ví dụ
Hãy cùng chúng tôi xem cách triển khai sau để hiểu rõ hơn -
#include <bits/stdc++.h>
using namespace std;
class Solution {
public:
int maximumProduct(vector<int>& nums) {
sort(nums.begin(), nums.end());
int l = nums.size();
int a = nums[l - 1], b = nums[l - 2], c = nums[l - 3], d = nums[0], e = nums[1];
return max(a * b * c, d * e * a);
}
};
main(){
Solution ob;
vector<int> v = {1,1,2,3,3};
cout << (ob.maximumProduct(v));
} Đầu vào
{1,1,2,3,3} Đầu ra
18