LeetCode C++ 1464. Maximum Product of Two Elements in an Array【Array/Sort】簡單
Given the array of integers nums
, you will choose two different indices i
and j
of that array. Return the maximum value of (nums[i] - 1) * (nums[j] - 1)
.
Example 1:
Input: nums = [3,4,5,2]
Output: 12
Explanation: If you choose the indices i=1 and j=2 (indexed from 0), you will get the maximum value, that is, (nums[1]-1)*(nums[2]-1) = (4-1)*(5-1) = 3*4 = 12.
Example 2:
Input: nums = [1,5,4,5]
Output: 16
Explanation: Choosing the indices i=1 and j=3 (indexed from 0), you will get the maximum value of (5-1)*(5-1) = 16.
Example 3:
Input: nums = [3,7]
Output: 12
Constraints:
2 <= nums.length <= 500
1 <= nums[i] <= 10^3
題意:給定一個整數陣列 nums
,選擇陣列的兩個不同下標 i
和 j
,使 (nums[i] - 1) * (nums[j] - 1)
取得最大值並返回。
解法1 暴力
class Solution {
public:
int maxProduct(vector<int>& nums) {
int mv = 0, n = nums.size();
for (int i = 0; i < n; ++i)
for (int j = i + 1; j < n; ++j)
mv = max(mv, (nums[i] - 1) * (nums[j] - 1));
return mv;
}
};
執行效率很低:
執行用時:60 ms, 在所有 C++ 提交中擊敗了6.69% 的使用者
記憶體消耗:10.2 MB, 在所有 C++ 提交中擊敗了13.32% 的使用者
解法2 排序
class Solution {
public:
int maxProduct(vector<int>& nums) {
sort(nums.begin(), nums.end(), greater<int>());
return (nums[0] - 1) * (nums[1] - 1);
}
};
執行效率如下:
執行用時:8 ms, 在所有 C++ 提交中擊敗了94.49% 的使用者
記憶體消耗:10 MB, 在所有 C++ 提交中擊敗了33.58% 的使用者
解法3 線性比較
class Solution {
public:
int maxProduct(vector<int>& nums) {
int max = 0, sec = 0, n = nums.size();
for (int i = 0; i < n; ++i) {
if (nums[i] > max) sec = max, max = nums[i];
else if (nums[i] > sec) sec = nums[i];
}
return (max - 1) * (sec - 1);
}
};
執行效率如下:
執行用時:4 ms, 在所有 C++ 提交中擊敗了99.53% 的使用者
記憶體消耗:10.2 MB, 在所有 C++ 提交中擊敗了12.91% 的使用者
相關文章
- Leetcode Sort ArrayLeetCode
- 421-Maximum XOR of Two Numbers in an Array
- LeetCode之Sort Array By Parity(Kotlin)LeetCodeKotlin
- [LeetCode] 238. Product of Array Except SelfLeetCode
- 【Leetcode】453. Minimum Moves to Equal Array ElementsLeetCode
- Sort Array By Parity
- 【Leetcode】167. Two Sum II - Input array is sortedLeetCode
- Cat, Fox and Maximum Array Split
- 238. Product of Array Except Self
- LeetCode | 152. Maximum Product SubarrayLeetCode
- Array.sort排序問題排序
- Rotate Array@LeetCodeLeetCode
- JavaScript object array sort by string bug All In OneJavaScriptObject
- LeetCode Kth Largest Element in an ArrayLeetCode
- LeetCode Patching Array All In OneLeetCode
- Leetcode每日一題:992.sort-array-by-parity-ii(按奇偶排序陣列Ⅱ)LeetCode每日一題排序陣列
- [LeetCode] 3090. Maximum Length Substring With Two OccurrencesLeetCode
- LeetCode 1305 All Elements in Two Binary Search TreesLeetCode
- LeetCode #1:Two Sum(簡單題)LeetCode
- .NET 排序 Array.Sort<T> 實現分析排序
- Leetcode 33 Search in Rotated Sorted ArrayLeetCode
- LeetCode之Squares of a Sorted Array(Kotlin)LeetCodeKotlin
- Leetcode 88. Merge Sorted ArrayLeetCode
- [LeetCode] 3152. Special Array IILeetCode
- LeetCode C++ 33. Search in Rotated Sorted Array【二分】中等LeetCodeC++
- Leetcode 26 Remove Duplicates from Sorted ArrayLeetCodeREM
- [LeetCode] 852. Peak Index in a Mountain ArrayLeetCodeIndexAI
- LeetCode Shuffle an Array(打亂陣列)LeetCode陣列
- Leetcode 442. Find All Duplicates in an ArrayLeetCode
- [leetcode] 1394. Find Lucky Integer in an ArrayLeetCode
- [LeetCode] 3011. Find if Array Can Be SortedLeetCode
- JavaScript中陣列Array.sort()排序方法詳解JavaScript陣列排序
- [LeetCode] 702. Search in a Sorted Array of Unknown SizeLeetCode
- python leetcode 215. Kth Largest Element in an ArrayPythonLeetCode
- LeetCode | 153. Find Minimum in Rotated Sorted ArrayLeetCode
- [leetcode]convert-sorted-array-to-binary-search-treeLeetCode
- [leetcode]remove-duplicates-from-sorted-array-iiLeetCodeREM
- [LeetCode] 1497. Check If Array Pairs Are Divisible by kLeetCodeAI