博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
[LeetCode] 3Sum Closest 最近三数之和
阅读量:6501 次
发布时间:2019-06-24

本文共 1353 字,大约阅读时间需要 4 分钟。

Given an array S of n integers, find three integers in S such that the sum is closest to a given number, target. Return the sum of the three integers. You may assume that each input would have exactly one solution.

For example, given array S = {-1 2 1 -4}, and target = 1.The sum that is closest to the target is 2. (-1 + 2 + 1 = 2).

这道题让我们求最接近给定值的三数之和,是在之前那道的基础上又增加了些许难度,那么这道题让我们返回这个最接近于给定值的值,即我们要保证当前三数和跟给定值之间的差的绝对值最小,所以我们需要定义一个变量diff用来记录差的绝对值,然后我们还是要先将数组排个序,然后开始遍历数组,思路跟那道三数之和很相似,都是先确定一个数,然后用两个指针left和right来滑动寻找另外两个数,每确定两个数,我们求出此三数之和,然后算和给定值的差的绝对值存在newDiff中,然后和diff比较并更新diff和结果closest即可,代码如下:

class Solution {public:    int threeSumClosest(vector
& nums, int target) { int closest = nums[0] + nums[1] + nums[2]; int diff = abs(closest - target); sort(nums.begin(), nums.end()); for (int i = 0; i < nums.size() - 2; ++i) { int left = i + 1, right = nums.size() - 1; while (left < right) { int sum = nums[i] + nums[left] + nums[right]; int newDiff = abs(sum - target); if (diff > newDiff) { diff = newDiff; closest = sum; } if (sum < target) ++left; else --right; } } return closest; }};

本文转自博客园Grandyang的博客,原文链接:,如需转载请自行联系原博主。

你可能感兴趣的文章
感恩节那天,亚洲诚信收到了一封来自客户的致谢信……
查看>>
网上看到的“12个非常有用的JavaScript技巧”
查看>>
Find系列回归背后,OPPO的探索精神有了新定义?
查看>>
“媒体艺术”如何在自我时代存活
查看>>
SAP CRM和C4C数据同步的两种方式概述:SAP PI和HCI
查看>>
java资深架构师分布式技术分享
查看>>
React as a UI Runtime(二、React元素和入口)
查看>>
前端_JavaScript_Vue
查看>>
【跃迁之路】【723天】程序员高效学习方法论探索系列(实验阶段480-2019.2.13)...
查看>>
高性能mongodb之利用javascript函数式编程玩转mongodb shell
查看>>
情人节来了!程序员应该如何优雅的度过?
查看>>
时间复杂度与空间复杂度分析
查看>>
Markdown常用标记使用
查看>>
Centos7下一键安装LNMP环境脚本
查看>>
新的开始!
查看>>
简单认识Hexo的目录结构
查看>>
Xamarin.Forms vs Xamarin Native
查看>>
RocketMQ生产者流程篇
查看>>
Golang 正则表达式(regexp)
查看>>
js ES6 求数组的交集,并集,还有差集
查看>>