2873. 有序三元组中的最大值 I
发表于更新于
字数总计:365阅读时长:1分钟 重庆
2873. 有序三元组中的最大值 I
题目
给你一个下标从 0 开始的整数数组 nums 。
请你从所有满足 i < j < k 的下标三元组 (i, j, k) 中,找出并返回下标三元组的最大值。如果所有满足条件的三元组的值都是负数,则返回 0 。
下标三元组 (i, j, k) 的值等于 (nums[i] - nums[j]) * nums[k] 。
示例 1:
1 2 3 4
| 输入:nums = [12,6,1,2,7] 输出:77 解释:下标三元组 (0, 2, 4) 的值是 (nums[0] - nums[2]) * nums[4] = 77 。 可以证明不存在值大于 77 的有序下标三元组。
|
示例 2:
1 2 3 4
| 输入:nums = [1,10,3,4,19] 输出:133 解释:下标三元组 (1, 2, 4) 的值是 (nums[1] - nums[2]) * nums[4] = 133 。 可以证明不存在值大于 133 的有序下标三元组。
|
示例 3:
1 2 3
| 输入:nums = [1,2,3] 输出:0 解释:唯一的下标三元组 (0, 1, 2) 的值是一个负数,(nums[0] - nums[1]) * nums[2] = -3 。因此,答案是 0 。
|
提示:
- 3 <= nums.length <= 100
- 1 <= nums[i] <= 106
思路
没啥好说的,暴力就完事了。
完整代码

1 2 3 4 5 6 7 8 9 10 11 12 13 14
| class Solution { public long maximumTripletValue(int[] nums) { long res=Long.MIN_VALUE; for(int i=0;i<nums.length;i++){ for(int j=i+1;j<nums.length;j++){ for(int k=j+1;k<nums.length;k++){ long ans=(long)(nums[i]-nums[j])*nums[k]; res=Math.max(res,ans); } } } return res<0?0:res; } }
|


Re-xy
正在运行...
本文遵循 CC BY-NC-SA 4.0 许可协议