刻意练习:LeetCode实战 -- Task05. 最接近的三数之和
作者:互联网
背景
本篇图文是LSGO软件技术团队组织的 第二期基础算法(Leetcode)刻意练习训练营 的打卡任务。本期训练营采用分类别练习的模式,即选择了五个知识点(数组、链表、字符串、树、贪心算法),每个知识点选择了 三个简单、两个中等、一个困难 等级的题目,共计三十道题,利用三十天的时间完成这组刻意练习。
本次任务的知识点:数组
数组 是在程序设计中,为了处理方便,把具有相同类型的若干元素按有序的形式组织起来的一种形式。抽象地讲,数组即是有限个类型相同的元素的有序序列。若将此序列命名,那么这个名称即为数组名。组成数组的各个变量称为数组的分量,也称为数组的元素。而用于区分数组的各个元素的数字编号则被称为下标,若为此定义一个变量,即为下标变量。
题目
给定一个包括n
个整数的数组nums
和一个目标值target
。找出nums
中的三个整数,使得它们的和与target
最接近。返回这三个数的和。假定每组输入只存在唯一答案。
示例 :
例如,给定数组 nums = [-1,2,1,-4], 和 target = 1.
与 target 最接近的三个数的和为 2. (-1 + 2 + 1 = 2).
算法实现
第一种:利用暴力算法
- 状态:通过
- 125 / 125 个通过测试用例
- 执行用时: 680 ms, 在所有 C# 提交中击败了 12.07% 的用户
- 内存消耗: 23.7 MB, 在所有 C# 提交中击败了 7.41% 的用户
public class Solution
{
public int ThreeSumClosest(int[] nums, int target)
{
double error = int.MaxValue;
int sum = 0;
for (int i = 0; i < nums.Length - 2; i++)
for (int j = i + 1; j < nums.Length - 1; j++)
for (int k = j + 1; k < nums.Length; k++)
{
if (Math.Abs(nums[i] + nums[j] + nums[k] - target) < error)
{
sum = nums[i] + nums[j] + nums[k];
error = Math.Abs(sum - target);
}
}
return sum;
}
}
第二种:利用双指针算法
- 状态:通过
- 125 / 125 个通过测试用例
- 执行用时: 132 ms, 在所有 C# 提交中击败了 100.00% 的用户
- 内存消耗: 24 MB, 在所有 C# 提交中击败了 5.55% 的用户
public class Solution {
public int ThreeSumClosest(int[] nums, int target) {
nums = nums.OrderBy(a => a).ToArray();
int result = nums[0] + nums[1] + nums[2];
for (int i = 0; i < nums.Length - 2; i++)
{
int start = i + 1, end = nums.Length - 1;
while (start < end)
{
int sum = nums[start] + nums[end] + nums[i];
if (Math.Abs(target - sum) < Math.Abs(target - result))
result = sum;
if (sum > target)
end--;
else if (sum < target)
start++;
else
return result;
}
}
return result;
}
}
Pyhton 语言
- 执行结果:通过
- 执行用时:124 ms, 在所有 Python3 提交中击败了 72.19% 的用户
- 内存消耗:13.2 MB, 在所有 Python3 提交中击败了 22.06% 的用户
class Solution:
def threeSumClosest(self, nums: List[int], target: int) -> int:
nums = sorted(nums)
result = nums[0] + nums[1] + nums[2]
for i in range(0, len(nums) - 2):
start = i + 1
end = len(nums) - 1
while start < end:
sum = nums[start] + nums[end] + nums[i]
if abs(target - sum) < abs(target - result):
result = sum
if sum > target:
end -= 1
elif sum < target:
start += 1
else:
return result
return result
来源
- https://leetcode-cn.com/problems/3sum-closest/
往期活动
LSGO软件技术团队会定期开展提升编程技能的刻意练习活动,希望大家能够参与进来一起刻意练习,一起学习进步!
- Python基础刻意练习活动即将开启,你参加吗?
- Task01:变量、运算符与数据类型
- Task02:条件与循环
- Task03:列表与元组
- Task04:字符串与序列
- Task05:函数与Lambda表达式
- Task06:字典与集合
- Task07:文件与文件系统
- Task08:异常处理
- Task09:else 与 with 语句
- Task10:类与对象
- Task11:魔法方法
- Task12:模块
我是 终身学习者“老马”,一个长期践行“结伴式学习”理念的 中年大叔。
我崇尚分享,渴望成长,于2010年创立了“LSGO软件技术团队”,并加入了国内著名的开源组织“Datawhale”,也是“Dre@mtech”、“智能机器人研究中心”和“大数据与哲学社会科学实验室”的一员。
愿我们一起学习,一起进步,相互陪伴,共同成长。
后台回复「搜搜搜」,随机获取电子资源!
欢迎关注,请扫描二维码:
标签:target,nums,int,三数,sum,start,result,Task05,LeetCode 来源: https://blog.csdn.net/LSGO_MYP/article/details/104682128