算法leetcode|16. 最接近的三数之和(rust重拳出击)
创始人
2024-04-12 01:24:35
0

文章目录

  • 16. 最接近的三数之和:
    • 样例 1:
    • 样例 2:
    • 提示:
    • 原题传送门:
  • 分析
  • 题解
    • rust
    • go
    • c++
    • java
    • typescript
    • python


16. 最接近的三数之和:

给你一个长度为 n 的整数数组 nums 和 一个目标值 target。请你从 nums 中选出三个整数,使它们的和与 target 最接近。

返回这三个数的和。

假定每组输入只存在恰好一个解。

样例 1:

输入:nums = [-1,2,1,-4], target = 1输出:2解释:与 target 最接近的和是 2 (-1 + 2 + 1 = 2) 。

样例 2:

输入:nums = [0,0,0], target = 1输出:0

提示:

  • 3 <= nums.length <= 1000
  • -1000 <= nums[i] <= 1000
  • -104 <= target <= 104

原题传送门:

https://leetcode.cn/problems/3sum-closest/


分析

  • 面对这道算法题目,二当家的陷入了沉思。
  • 这道题和【15. 三数之和】很像,但是不再是找一个值,而是要把可能的值都找一遍,最后确定最接近的值,所以不再是直接跳过大于目标,或者小于目标的值。
  • 由于有三个变量,直观的做法还是暴力三层循环,但还是传说会超时。
  • 同样我们先排个序,可以外层循环遍历作为第一个数。
  • 这里用到双指针的思想,如果是找最接近的两数之和,我们可以将两个指针先定位在有序数组的两端,去判断两数之和是否和目标相等,如果相等就是想要的结果;如果大于目标,我们向左移动右面的指针;如果小于目标,我们就向右移动左边的指针。(如果右面的指针一直向左移动就会让两数之和最小,反之如果让左面的指针一直向右移动就会使两数之和最大,这样两个指针的移动方向虽然固定了,但是却不会漏掉某种组合)
  • 扩展到三数之和,由于外层循环已经确定了第一个数的值,内层其实就是最接近的两数之和。

题解

rust

impl Solution {pub fn three_sum_closest(mut nums: Vec, target: i32) -> i32 {let n = nums.len();nums.sort();let mut ans = 23001;for f in 0..n {if f == 0 || nums[f] != nums[f - 1] {let mut s = f + 1;let mut t = n - 1;while s < t {let sum = nums[f] + nums[s] + nums[t];if sum == target {return target;}if (sum - target).abs() < (ans - target).abs() {ans = sum;}if sum > target {let mut t0 = t - 1;while s < t0 && nums[t0] == nums[t] {t0 -= 1;}t = t0;} else {let mut s0 = s + 1;while s0 < t && nums[s0] == nums[s] {s0 += 1;}s = s0;}}}}return ans;}
}

go

func threeSumClosest(nums []int, target int) int {n := len(nums)sort.Ints(nums)ans := 23001abs := func(num int) int {if num < 0 {return -num}return num}for f := 0; f < n; f++ {if f > 0 && nums[f] == nums[f-1] {continue}s, t := f+1, n-1for s < t {sum := nums[f] + nums[s] + nums[t]if sum == target {return target}if abs(sum-target) < abs(ans-target) {ans = sum}if sum > target {t0 := t - 1for s < t0 && nums[t0] == nums[t] {t0 -= 1}t = t0} else {s0 := s + 1for s0 < t && nums[s0] == nums[s] {s0 += 1}s = s0}}}return ans
}

c++

class Solution {
public:int threeSumClosest(vector& nums, int target) {int n = nums.size();sort(nums.begin(), nums.end());int ans = 23001;for (int f = 0; f < n; ++f) {if (f > 0 && nums[f] == nums[f - 1]) {continue;}int s = f + 1;int t = n - 1;while (s < t) {int sum = nums[f] + nums[s] + nums[t];if (sum == target) {return target;}if (abs(sum - target) < abs(ans - target)) {ans = sum;}if (sum > target) {int t0 = t - 1;while (s < t0 && nums[t0] == nums[t]) {t0 -= 1;}t = t0;} else {int s0 = s + 1;while (s0 < t && nums[s0] == nums[s]) {s0 += 1;}s = s0;}}}return ans;}
};

java

class Solution {public int threeSumClosest(int[] nums, int target) {int n = nums.length;Arrays.sort(nums);int ans = 23001;for (int f = 0; f < n; ++f) {if (f > 0 && nums[f] == nums[f - 1]) {continue;}int s = f + 1;int t = n - 1;while (s < t) {int sum = nums[f] + nums[s] + nums[t];if (sum == target) {return target;}if (Math.abs(sum - target) < Math.abs(ans - target)) {ans = sum;}if (sum > target) {int t0 = t - 1;while (s < t0 && nums[t0] == nums[t]) {t0 -= 1;}t = t0;} else {int s0 = s + 1;while (s0 < t && nums[s0] == nums[s]) {s0 += 1;}s = s0;}}}return ans;}
}

typescript

function threeSumClosest(nums: number[], target: number): number {const n = nums.length;nums.sort((a, b) => a - b);let ans = 23001;for (let f = 0; f < nums.length; ++f) {if (f > 0 && nums[f] === nums[f - 1]) {continue;}let s = f + 1;let t = n - 1;while (s < t) {const sum = nums[f] + nums[s] + nums[t];if (sum === target) {return target;}if (Math.abs(sum - target) < Math.abs(ans - target)) {ans = sum;}if (sum > target) {let t0 = t - 1;while (s < t0 && nums[t0] === nums[t]) {t0 -= 1;}t = t0;} else {let s0 = s + 1;while (s0 < t && nums[s0] === nums[s]) {s0 += 1;}s = s0;}}}return ans;
};

python

class Solution:def threeSumClosest(self, nums: List[int], target: int) -> int:n = len(nums)nums.sort()ans = 23001for f in range(n):if f > 0 and nums[f] == nums[f - 1]:continues = f + 1t = n - 1while s < t:sum = nums[f] + nums[s] + nums[t]if sum == target:return targetif abs(sum - target) < abs(ans - target):ans = sumif sum > target:t0 = t - 1while s < t0 and nums[t0] == nums[t]:t0 -= 1t = t0else:s0 = s + 1while s0 < t and nums[s0] == nums[s]:s0 += 1s = s0return ans

非常感谢你阅读本文~
欢迎【点赞】【收藏】【评论】~
放弃不难,但坚持一定很酷~
希望我们大家都能每天进步一点点~
本文由 二当家的白帽子:https://le-yi.blog.csdn.net/ 博客原创~


相关内容

热门资讯

银河麒麟V10SP1高级服务器... 银河麒麟高级服务器操作系统简介: 银河麒麟高级服务器操作系统V10是针对企业级关键业务...
【NI Multisim 14...   目录 序言 一、工具栏 🍊1.“标准”工具栏 🍊 2.视图工具...
AWSECS:访问外部网络时出... 如果您在AWS ECS中部署了应用程序,并且该应用程序需要访问外部网络,但是无法正常访问,可能是因为...
不能访问光猫的的管理页面 光猫是现代家庭宽带网络的重要组成部分,它可以提供高速稳定的网络连接。但是,有时候我们会遇到不能访问光...
AWSElasticBeans... 在Dockerfile中手动配置nginx反向代理。例如,在Dockerfile中添加以下代码:FR...
Android|无法访问或保存... 这个问题可能是由于权限设置不正确导致的。您需要在应用程序清单文件中添加以下代码来请求适当的权限:此外...
月入8000+的steam搬砖... 大家好,我是阿阳 今天要给大家介绍的是 steam 游戏搬砖项目,目前...
​ToDesk 远程工具安装及... 目录 前言 ToDesk 优势 ToDesk 下载安装 ToDesk 功能展示 文件传输 设备链接 ...
北信源内网安全管理卸载 北信源内网安全管理是一款网络安全管理软件,主要用于保护内网安全。在日常使用过程中,卸载该软件是一种常...
AWS管理控制台菜单和权限 要在AWS管理控制台中创建菜单和权限,您可以使用AWS Identity and Access Ma...