当前位置: 首页 > article >正文

算法每日一练 (25)

💢欢迎来到张翊尘的技术站
💥技术如江河,汇聚众志成。代码似星辰,照亮行征程。开源精神长,传承永不忘。携手共前行,未来更辉煌💥

文章目录

  • 算法每日一练 (25)
    • 四数之和
      • 题目描述
      • 解题思路
      • 解题代码
        • `c/c++`
        • `golang`
        • `lua`

官方站点: 力扣 Leetcode

算法每日一练 (25)

四数之和

题目地址:四数之和

题目描述

给你一个由 n 个整数组成的数组 nums ,和一个目标值 target 。请你找出并返回满足下述全部条件且不重复的四元组 [nums[a], nums[b], nums[c], nums[d]] (若两个四元组元素一一对应,则认为两个四元组重复):

  • 0 <= a, b, c, d < n
  • abcd 互不相同
  • nums[a] + nums[b] + nums[c] + nums[d] == target

你可以按 任意顺序 返回答案 。

示例 1:

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

示例 2:

输入:nums = [2,2,2,2,2], target = 8
输出:[[2,2,2,2]]

提示:

  • 1 <= nums.length <= 200
  • -109 <= nums[i] <= 109
  • -109 <= target <= 109

解题思路

  • 本题解法采用了回溯的思路。

本题可以采用双指针进行算法优化,感兴趣的小伙伴可以自行查阅。

  • 由题意可知,四元组需要满足以下条件:
    • 四元组中的数字可以按任意顺序排列。
    • 解集不能包含重复的四元组。
  • 整体代码分为了两部分:
    • fourSum:这是主函数,负责初始化和调用回溯函数。
    • traceback:这是一个递归函数,用于通过回溯法生成所有可能的四元组。
  • 首先对输入数组 nums 进行排序。排序的目的是为了方便后续去重和剪枝操作。
  • 紧接着,创建辅助集合 t 和结果集合 res:
    • t 是一个临时向量,用于存储当前递归路径中的数字。
    • res 是最终结果,用于存储所有满足条件的四元组。
  • 然后调用回溯函数 traceback,该函数的逻辑主要分为以下几部分:
    • 递归终止条件
      • 如果 t 的大小超过 4,则直接返回,因为四元组最多只能有 4 个数字。
      • 如果 t 的大小恰好为 4,检查当前和 cursum 是否等于目标值 target。如果相等,则将 t 添加到结果 res 中。
    • 循环遍历
      • 从当前索引 index 开始,遍历数组中的每个数字。
      • 去重:如果当前数字与前一个数字相同(nums[i] == nums[i - 1]),则跳过当前数字,避免重复解。
      • 剪枝:如果当前和加上当前数字已经大于目标值,并且当前数字是非负数,则直接跳出循环,因为后续数字只会更大。
      • 递归调用:将当前数字加入临时向量 t,递归调用 traceback,并将当前索引加 1,当前和加上当前数字。
      • 回溯:递归返回后,将当前数字从 t 中移除,继续尝试下一个数字。
  • 最后着重强调:本题目采用回溯法时间复杂度较高,尤其是在数组较大时,可能会导致性能瓶颈

解题代码

c/c++
#include <vector>
#include <algorithm>class Solution
{
public:std::vector<std::vector<int>> fourSum(std::vector<int> &nums, int target){std::vector<int> t;std::vector<std::vector<int>> res;std::sort(nums.begin(), nums.end());traceback(nums, t, target, 0, 0, res);return res;}private:void traceback(std::vector<int> &nums, std::vector<int> &t,int target, int index, long long int cursum,std::vector<std::vector<int>> &res){int sz = t.size();if (sz > 4)return;if (sz == 4){if (cursum == target)res.push_back(t);return;}for (int i = index; i < nums.size(); i++){if (i > index && nums[i] == nums[i - 1])continue;if (cursum + nums[i] > target && nums[i] >= 0)break;t.push_back(nums[i]);traceback(nums, t, target, i + 1, cursum + nums[i], res);t.pop_back();}}
};
golang
import "sort"func fourSum(nums []int, target int) [][]int {res := make([][]int, 0)sort.Ints(nums)traceback(nums, []int{}, target, 0, 0, &res)return res
}func traceback(nums []int, t []int, target, index, cursum int, res *[][]int) {sz := len(t)if sz > 4 {return}if sz == 4 {if cursum == target {r := make([]int, sz)copy(r, t)*res = append(*res, r)}return}for i := index; i < len(nums); i++ {if i > index && nums[i] == nums[i-1] {continue}if cursum+nums[i] > target && nums[i] >= 0 {break}t = append(t, nums[i])traceback(nums, t, target, i+1, cursum+nums[i], res)t = t[:len(t)-1]}
}
lua
local function copyTable(dst, src)for i = 1, #src dodst[i] = src[i]end
endlocal function traceback(nums, t, target, index, cursum, res)local sz = #tif sz > 4 thenreturnendif sz == 4 thenif cursum == target thenlocal dst = {}copyTable(dst, t)table.insert(res, dst)endreturnendfor i = index, #nums doif i > index and nums[i] == nums[i - 1] thengoto continueendtable.insert(t, nums[i])traceback(nums, t, target, i + 1, cursum + nums[i], res)table.remove(t, #t)::continue::end
endlocal function fourSum(nums, target)local res = {}local t = {}table.sort(nums)traceback(nums, t, target, 1, 0, res)return res
end

🌺🌺🌺撒花!

如果本文对你有帮助,就点关注或者留个👍
如果您有任何技术问题或者需要更多其他的内容,请随时向我提问。

在这里插入图片描述

相关文章:

算法每日一练 (25)

&#x1f4a2;欢迎来到张翊尘的技术站 &#x1f4a5;技术如江河&#xff0c;汇聚众志成。代码似星辰&#xff0c;照亮行征程。开源精神长&#xff0c;传承永不忘。携手共前行&#xff0c;未来更辉煌&#x1f4a5; 文章目录 算法每日一练 (25)四数之和题目描述解题思路解题代码c…...

【大模型基础_毛玉仁】6.4 生成增强

目录 6.4 生成增强6.4.1 何时增强1&#xff09;外部观测法2&#xff09;内部观测法 6.4.2 何处增强6.4.3 多次增强6.4.4 降本增效1&#xff09;去除冗余文本2&#xff09;复用计算结果 6.4 生成增强 检索器得到相关信息后&#xff0c;将其传递给大语言模型以期增强模型的生成能…...

Zephyr实时操作系统初步介绍

一、概述 Zephyr是由Linux基金会托管的开源实时操作系统&#xff08;RTOS&#xff09;&#xff0c;专为资源受限的物联网设备设计。其核心特性包括模块化架构、跨平台兼容性、安全性优先以及丰富的连接协议支持。基于Apache 2.0协议&#xff0c;Zephyr允许商业和非商业用途的自…...

【GCC警告报错4】warning: format not a string literal and no format arguments

文章主本文根据笔者个人工作/学习经验整理而成&#xff0c;如有错误请留言。 文章为付费内容&#xff0c;已加入原创保护&#xff0c;禁止私自转载。 文章发布于&#xff1a;《C语言编译报错&警告合集》 如图所示&#xff1a; 原因&#xff1a; snprintf的函数原型&#x…...

【落羽的落羽 C++】模板简介

文章目录 一、模板的引入二、函数模板1. 函数模板的使用2. 函数模板的原理3. 函数模板的实例化4. 函数模板的匹配 三、类模板 一、模板的引入 假如我们想写一个Swap函数&#xff0c;针对每一种类型&#xff0c;都要函数重载写一次&#xff0c;但它们的实现原理是几乎一样的。在…...

USB(通用串行总线)数据传输机制和包结构简介

目录 1. USB的物理连接电缆结构时钟恢复技术 2. USB的数据传输方式包&#xff08;Packet&#xff09; 3. 包的传输规则帧和微帧 4. 包的结构1. 同步字段&#xff08;Sync&#xff09;2. 包标识符字段&#xff08;PID&#xff09;3. 数据字段4. 循环冗余校验字段&#xff08;CRC…...

【目标检测】【深度学习】【Pytorch版本】YOLOV3模型算法详解

【目标检测】【深度学习】【Pytorch版本】YOLOV3模型算法详解 文章目录 【目标检测】【深度学习】【Pytorch版本】YOLOV3模型算法详解前言YOLOV3的模型结构YOLOV3模型的基本执行流程YOLOV3模型的网络参数 YOLOV3的核心思想前向传播阶段反向传播阶段 总结 前言 YOLOV3是由华盛顿…...

【前端扫盲】postman介绍及使用

Postman 是一款专为 API 开发与测试设计的 全流程协作工具&#xff0c;程序员可通过它高效完成接口调试、自动化测试、文档管理等工作。以下是针对程序员的核心功能介绍和应用场景说明&#xff1a; 一、核心功能亮点 接口请求构建与调试 支持所有 HTTP 方法&#xff08;GET/POS…...

每日c/c++题 备战蓝桥杯(全排列问题)

题目描述 按照字典序输出自然数 1 到 n 所有不重复的排列&#xff0c;即 n 的全排列&#xff0c;要求所产生的任一数字序列中不允许出现重复的数字。 输入格式 一个整数 n。 输出格式 由 1∼n 组成的所有不重复的数字序列&#xff0c;每行一个序列。 每个数字保留 5 个场…...

IdeaVim-AceJump

‌AceJump 是一款专为IntelliJ IDEA平台打造的开源插件&#xff0c;旨在通过简单的快捷键操作帮助用户快速跳转到编辑器中的任何符号位置&#xff0c;如变量名、方法调用或特定的字符串‌。无论是大型项目还是日常编程&#xff0c;AceJump 都能显著提升你的代码导航速度和效率。…...

BMS电池关键参数及其含义

BMS概述 BMS的定义与功能 BMS&#xff0c;即电池管理系统&#xff0c;是电池系统的核心控制设备&#xff0c;充当着电池的“状态观测器”。它通过传感器采集电池的单体电压、温度、电流等关键参数&#xff0c;并利用电子控制单元&#xff08;ECU&#xff09;进行数据处理和分…...

DataFrame行索引操作以及重置索引

一.DataFrame行索引操作 1.1 获取数据 1.1.1 loc 选取数据 df.loc[ ] 只能使用标签索引&#xff0c;不能使用整数索引。 当通过标签索引的切片方式来筛选数据时&#xff0c;它的取值前闭后闭。 传参&#xff1a; 1.如果选择单行或单列&#xff0c;返回的数据类型为 Series…...

DayDreamer: World Models forPhysical Robot Learning

DayDreamer&#xff1a;用于物理机器人学习的世界模型 Philipp Wu* Alejandro Escontrela* Danijar Hafner* Ken Goldberg Pieter Abbeel 加州大学伯克利分校 *贡献相同 摘要&#xff1a;为了在复杂环境中完成任务&#xff0c;机器人需要从经验中学习。深度强化学习是机器人学…...

线性欧拉筛

线性筛&#xff1a;高效求解素数 在数论中&#xff0c;素数的筛选是一个经典的问题。最常见的素数筛选方法是埃拉托斯特尼筛法&#xff0c;其时间复杂度为 O ( n log ⁡ log ⁡ n ) O(n\log \log n) O(nloglogn)&#xff0c;非常适合求解小范围内的素数。随着问题规模的增大&…...

Flutter vs React Native:跨平台移动开发框架对比

文章目录 前言1. 框架概述什么是 Flutter&#xff1f;什么是 React Native&#xff1f; 2. 性能对比Flutter 的性能表现React Native 的性能表现总结&#xff1a; 3. 开发体验对比3.1 开发效率3.2 UI 组件库 4. 生态系统对比5. 适用场景分析6. 结论&#xff1a;如何选择&#x…...

用matlab搭建一个简单的图像分类网络

文章目录 1、数据集准备2、网络搭建3、训练网络4、测试神经网络5、进行预测6、完整代码 1、数据集准备 首先准备一个包含十个数字文件夹的DigitsData&#xff0c;每个数字文件夹里包含1000张对应这个数字的图片&#xff0c;图片的尺寸都是 28281 像素的&#xff0c;如下图所示…...

AI辅助开发插件

适合Java程序员的AI辅助开发插件&#xff0c;按功能和适用场景分类&#xff1a; 1. 飞算JavaAI • 特点&#xff1a;从需求分析到代码生成的全流程智能引导&#xff0c;支持Maven、Gradle等主流工具&#xff0c;一键生成完整工程代码&#xff0c;包括配置文件、源代码和测试资…...

【AI4CODE】5 Trae 锤一个基于百度Amis的Crud应用

【AI4CODE】目录 【AI4CODE】1 Trae CN 锥安装配置与迁移 【AI4CODE】2 Trae 锤一个 To-Do-List 【AI4CODE】3 Trae 锤一个贪吃蛇的小游戏 【AI4CODE】4 Trae 锤一个数据搬运工的小应用 1 百度 Amis 简介 百度 Amis 是一个低代码前端框架&#xff0c;由百度开源。它通过 J…...

npm webpack打包缓存 导致css引用地址未更新

问题如下&#xff1a; 测试环境配置&#xff1a; publicPath: /chat/,生产环境配置&#xff1a; publicPath: /,css中引用背景图片 background-image: url(/assets/images/calendar/arrow-left.png);先打包测试环境&#xff0c;观察打包后的css文件引用的背景图片地址 可以全…...

ollama导入huggingface下载的大模型并量化

1. 导入GGUF 类型的模型 1.1 先在huggingface 下载需要ollama部署的大模型 1.2 编写modelfile 在ollama 里面输入 ollama show --modelfile <你有的模型名称> eg: ollama show --modelfile qwen2.5:latest修改其中的from 路径为自己的模型下载路径 FROM /Users/lzx/A…...

Java 集合 Map Stream流

目录 集合遍历for each map案例 ​编辑 这种数组的遍历是【index】​编辑map排序【对象里重写compareTo​编辑map排序【匿名内部类lambda​编辑 stream流​编辑 ​编辑获取&#xff1a; map的键是set集合&#xff0c;获取方法map.keySet() map的值是collection 集合&…...

记录一下零零散散的的东西-ImageNet

ImageNet 是一个非常著名的大型图像识别数据集&#xff0c; 数据集基本信息 内容说明&#x1f4f8; 图像数量超过 1400万张图片&#xff08;包含各类子集&#xff09;&#x1f3f7;️ 类别数量常用的是 ImageNet-1K&#xff08;1000类&#xff09;&#x1f9d1;‍&#x1f3e…...

【网络安全实验】PKI(证书服务)配置实验

目录 一、PKI相关概念 1.1 定义与核心功能 1.2 PKI 系统的组成 1.证书颁发机构&#xff08;CA, Certificate Authority&#xff09; 2.注册机构&#xff08;RA, Registration Authority&#xff09; 3.数字证书 1.3 PKI 的功能 1.4 PKI认证体系&#xff1a; 工作流程 …...

【数据集】多视图文本数据集

多视图文本数据集指的是包含多个不同类型或来源的信息的文本数据集。不同视图可以来源于不同的数据模式&#xff08;如原始文本、元数据、网络结构等&#xff09;&#xff0c;或者不同的文本表示方法&#xff08;如 TF-IDF、词嵌入、主题分布等&#xff09;。这些数据集常用于多…...

学透Spring Boot — 007. 七种配置方式及优先级

Spring Boot 提供很多种方式来加载配置&#xff0c;本文我们会用Tomcat的端口号作为例子&#xff0c;演示Spring Boot 常见的配置方式。 几种配置方式 使用默认配置 新建一个项目什么都不配置&#xff0c;Spring Boot会自动配置Tomcat端口号。 启动日志 TomcatWebServer :…...

元素定位-xpath

xpath其实就是一个path(路径)&#xff0c;一个描述页面元素位置信息的路径&#xff0c;相当于元素的坐标xpath基于XML文档树状结构&#xff0c;是XML路径语言&#xff0c;用来查询xml文档中的节点。 绝对定位 从根开始找--/(根目录)/html/body/div[2]/div/form/div[5]/button缺…...

【youcans论文精读】弱监督深度检测网络(Weakly Supervised Deep Detection Networks)

欢迎关注『youcans论文精读』系列 本专栏内容和资源同步到 GitHub/youcans 【youcans论文精读】弱监督深度检测网络 WSDDN 0. 弱监督检测的开山之作0.1 论文简介0.2 WSDNN 的步骤0.3 摘要 1. 引言2. 相关工作3. 方法3.1 预训练网络3.2 弱监督深度检测网络3.3 WSDDN训练3.4 空间…...

网络购物谨慎使用手机免密支付功能

在数字经济蓬勃发展的当下&#xff0c;“免密支付”成为许多人消费时的首选支付方式。 “免密支付”的存在有其合理性。在快节奏的现代生活中&#xff0c;时间愈发珍贵&#xff0c;每节省一秒都可能带来更高的效率。以日常通勤为例&#xff0c;上班族乘坐交通工具时&#xff0c…...

Sentinel[超详细讲解]-4

&#x1f693; 主要讲解流控模式的 三种方式中的两种&#xff1a; 直接、链路&#x1f680; 1️⃣ 直接模式 &#x1f68e; 直接模式&#xff1a;对资源本身进行限流&#xff0c;例如对某个接口进行限流&#xff0c;当该接口的访问频率超过设定的阈值时&#xff0c;直接拒绝新的…...

【服务日志链路追踪】

MDCInheritableThreadLocal和spring cloud sleuth 在微服务架构中&#xff0c;日志链路追踪&#xff08;Logback Distributed Tracing&#xff09; 是一个关键需求&#xff0c;主要用于跟踪请求在不同服务间的调用链路&#xff0c;便于排查问题。常见的实现方案有两种&#x…...