(leetcode学习)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

没什么好的思路,先暴力一下,打败10%

cpp 复制代码
int threeSumClosest(vector<int>& nums, int target) {
	sort(nums.begin(), nums.end());
	int res, diff = INT_MAX, nums_len = nums.size();
	if (target >= 3 * nums[nums_len - 1]) return nums[nums_len - 1] + nums[nums_len - 2] + nums[nums_len - 3];
	if (target <= 3 * nums[0]) return nums[0] + nums[1] + nums[2];

	for (int i = 0; i < nums_len; i++) {
		if (i != 0 && nums[i] == nums[i - 1]) continue;
		for (int j = i + 1; j < nums_len; j++) {
			if (j != i + 1 && nums[j] == nums[j - 1]) continue;
			int cur_diff = INT_MAX, cur_res;
			for (int k = j + 1; k < nums_len; k++) {
				if (abs(nums[i] + nums[j] + nums[k] - target) > cur_diff) break;
				cur_diff = abs(nums[i] + nums[j] + nums[k] - target);
				cur_res = nums[i] + nums[j] + nums[k];
			}
			if (cur_diff < diff) {
				res = cur_res;
				diff = cur_diff;
			}	
		}
	}
	return res;
}
相关推荐
GoppViper1 分钟前
golang学习笔记24——golang微服务中配置管理问题的深度剖析
笔记·后端·学习·微服务·golang·配置管理
敲代码的奥豆3 分钟前
C++:日期类的实现
开发语言·c++
向往风的男子10 分钟前
【从问题中去学习k8s】k8s中的常见面试题(夯实理论基础)(三十)
学习·容器·kubernetes
徊忆羽菲17 分钟前
学习使用在windows系统上安装vue前端框架以及环境配置图文教程
vue.js·学习·前端框架
攸攸太上35 分钟前
Java通配符的作用
java·学习·通配符
蜡笔小新星39 分钟前
机器学习和深度学习的区别
开发语言·人工智能·经验分享·深度学习·学习·机器学习
东京老树根1 小时前
SAP学习笔记 - 开发06 - CDSView + Fiori Element 之 List Report
笔记·学习
Dovir多多1 小时前
渗透测试入门学习——php表单form与POST、GET请求练习
学习·安全·web安全·网络安全·系统安全·php·xss
redcocal1 小时前
地平线内推码 kbrfck
c++·嵌入式硬件·mcu·算法·fpga开发·求职招聘
归去来兮★1 小时前
c++面向对象
java·开发语言·c++