【LeetCode_数组_双指针】16. 最接近的三数之和
admin
2024-05-01 14:22:58

目录

  • 第一次:2022年12月27日10:20:52
    • 解题思路
    • 注意点
    • 代码展示

题目描述

16. 最接近的三数之和

第一次:2022年12月27日10:20:52

解题思路

双指针

详情可查看这个图解:画解算法:16. 最接近的三数之和

注意点

  • 返回值的初始值
    可以直接排序后,选取前三个。从题目中可以看出,数组最少都会有三个数。
  • 最接近的值怎么取舍
    使用数学中的取绝对值
  • 双指针的左移右移
    因为是首先对数组进行排序了,
    所以当前的和 比 期望值大了,肯定是缩小,所以移动的就是右指针,当前的和 比 期望值小了,扩大,移动左指针。

代码展示

class Solution {public int threeSumClosest(int[] nums, int target) {int length = nums.length;// 返回值的初始值int ans = nums[0] + nums[1] + nums[2];Arrays.sort(nums);for (int i = 0; i < length; i++) {int fast = length - 1;int slow = i + 1;while (slow < fast){int sum = nums[i] + nums[slow] + nums[fast];// 最接近的值怎么取舍if(Math.abs(target - sum) < Math.abs(target - ans)){ans = sum;}// 双指针的移动if (sum > target) {fast--;}else if (sum == target){return ans;}else {slow++;}}}return ans;}public static void main(String[] args) {Solution solution = new Solution();int threeSumClosest = solution.threeSumClosest(new int[]{4,0,5,-5,3,3,0,-4,-5}, -2);System.out.println(threeSumClosest);}
}

相关内容

热门资讯

天山冰雪迎客来(图片新闻) 天... 新疆维吾尔自治区昌吉回族自治州天山天池风景区利用丰富的冰雪旅游资源开展多场文化、体育、旅游等冰雪相关...
喝酒,要选晚上,才不会误事!暮... 喝酒,要选晚上,才不会误事! 暮色四合时小酌最为相宜。这不仅顺应人体自然节律,更蕴含着养生妙谛。晨...
吃广西横县的鸭肉生,端上桌鸭肉... 作者丨发财金刚 广西横县人对美食的追求,有自己的一套赤诚法则。 高端的食材往往只需要简单的烹饪,这句...
白茶的冲泡方法 冲泡白茶常见的方法有杯泡法、壶泡法、煮饮法、盖碗法、冷泡法等。 (1) 杯泡法。对于白毫银针和等级较...
原创 川... 标题:川菜大厨:腌腊肉时,别只会放盐,多做2步,腊味提升“1倍” 在四川的厨房里,腌制腊肉是一门艺...