标签:解释 pairs 依次 拆分 class code 正整数 数组 最大
给定长度为 2n 的数组, 你的任务是将这些数分成 n 对, 例如 (a1, b1), (a2, b2), ..., (an, bn) ,使得从1 到 n 的 min(ai, bi) 总和最大。
示例 1:
输入: [1,4,3,2]
输出: 4
解释: n 等于 2, 最大总和为 4 = min(1, 2) + min(3, 4).
提示:
先给数组排个序,然后依次加上两两中最小的一个。
class Solution {
public int arrayPairSum(int[] nums) {
if(nums.length == 2)
return Math.min(nums[0], nums[1]);
int sub = 0;
int n = nums.length / 2;
Arrays.sort(nums);
for(int i = 0; i < nums.length; i++) {
sub += Math.min(nums[i], nums[i++]);
}
return sub;
}
}
标签:解释 pairs 依次 拆分 class code 正整数 数组 最大
原文地址:https://www.cnblogs.com/Tu9oh0st/p/10704504.html