题目地址
难度:⭐
题目描述:
给你一个整数数组 nums
,请你选择数组的两个不同下标 i
和 j
,使 (nums[i]-1)*(nums[j]-1)
取得最大值。
请你计算并返回该式的最大值。
示例1:
1 2 3
| 输入:nums = [3,4,5,2] 输出:12 解释:如果选择下标 i=1 和 j=2(下标从 0 开始),则可以获得最大值,(nums[1]-1)*(nums[2]-1) = (4-1)*(5-1) = 3*4 = 12 。
|
示例2:
1 2 3
| 输入:nums = [1,5,4,5] 输出:16 解释:选择下标 i=1 和 j=3(下标从 0 开始),则可以获得最大值 (5-1)*(5-1) = 16 。
|
示例3:
提示:
2 <= nums.length <= 500
1 <= nums[i] <= 10^3
🙋♂️🙋♂️🙋♂️🙋♂️🙋♂️🙋♂️🙋♂️🙋♂️🙋♂️🙋♂️🙋♂️🙋♂️🙋♂️🙋♂️🙋♂️解题过程🙋♂️🙋♂️🙋♂️🙋♂️🙋♂️🙋♂️🙋♂️🙋♂️🙋♂️🙋♂️🙋♂️🙋♂️🙋♂️🙋♂️🙋♂️
解题过程:
思路:
调用< algorithm>头文件中的sort方法进行排序(默认升序),然后用最后两个元素计算最大值返回。
c++代码:(执行用时16ms,击败46.21%,内存消耗10.1M,击败32.85%)
1 2 3 4 5 6 7 8
| class Solution { public: int maxProduct(vector<int>& nums) { sort(nums.begin(),nums.end()); return (nums[nums.size()-1]-1)*(nums[nums.size()-2]-1); } };
|
⏳⏳⏳⏳⏳⏳⏳⏳⏳⏳⏳⏳⏳⏳⏳⏳⏳⏳⏳⏳总 结⏳⏳⏳⏳⏳⏳⏳⏳⏳⏳⏳⏳⏳⏳⏳⏳⏳⏳⏳⏳
总结:
没有官方题解(😍),简单题刷过了就可以了。