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

代码随想录算法训练营第六天 | Leetcode 454.四数相加 | 383.赎金信 | 15.三数之和 | 18.四数之和

day6 – 哈希表part02454.四数相加力扣题目链接454. 四数相加 II - 力扣LeetCode文章讲解第454题.四数相加II | 哈希表 | map | 统计查找 | 代码随想录视频讲解学透哈希表map使用有技巧LeetCode454.四数相加II_哔哩哔哩_bilibilipublicclassSolution{publicintFourSumCount(int[]nums1,int[]nums2,int[]nums3,int[]nums4){intnnums1.Length;Dictionaryint,intn12newDictionaryint,int();//a,b两数之和 -- 出现的次数Dictionaryint,intn34newDictionaryint,int();//分治思想intcount0;for(inti0;in;i){//记录n12for(intj0;jn;j){inttmpnums1[i]nums2[j];if(!n12.ContainsKey(tmp)){n12.Add(tmp,1);}else{n12[tmp];}}}for(inti0;in;i){//记录n34for(intj0;jn;j){inttmpnums3[i]nums4[j];if(!n34.ContainsKey(tmp)){n34.Add(tmp,1);}else{n34[tmp];}}}foreach(intiinn12.Keys){//遍历计数if(n34.ContainsKey(-i)){countn12[i]*n34[-i];}}returncount;}}383.赎金信力扣题目链接383. 赎金信 - 力扣LeetCode文章讲解383. 赎金信 | 哈希法 | 数组 | 代码随想录很简单的记录和查找是否有匹配字母只是运用了哈希表Dictionary降低了查找步骤的时间复杂度publicclassSolution{publicboolCanConstruct(stringransomNote,stringmagazine){Dictionarychar,inthnewDictionarychar,int();foreach(chariinmagazine){if(!h.ContainsKey(i)){h.Add(i,1);}else{h[i];}}foreach(chariinransomNote){if(!h.ContainsKey(i)){returnfalse;}else{h[i]--;if(h[i]0){h.Remove(i);}}}returntrue;}}15.三数之和力扣题目链接15. 三数之和 - 力扣LeetCode文章讲解第15题. 三数之和 | 双指针 | 哈希法 | 去重 | 代码随想录视频讲解梦破碎的地方| LeetCode15.三数之和_哔哩哔哩_bilibili如果用哈希法做此题去重操作会十分繁琐容易超时故有双指针做法publicclassSolution{publicIListIListintThreeSum(int[]nums){ListIListintansnewListIListint();//List继承IList接口Array.Sort(nums);for(inti0;inums.Length-2;i){if(nums[i]0){break;}//剪枝//去重第一个数字if(i0nums[i]nums[i-1])continue;// 注意不能是nums[i] nums[i 1]哦intrightnums.Length-1;intlefti1;while(leftright){intsumnums[i]nums[left]nums[right];if(sum0){right--;}elseif(sum0){left;}else{//sum 0ans.Add(newListint{nums[i],nums[left],nums[right]});//去重后两个数字left;right--;//不可能只变动一个还有正解while(leftrightnums[left]nums[left-1])left;while(leftrightnums[right]nums[right1])right--;//leftright确保不会一直加或者一直减到越界}}}returnans;}}较为复杂详见讲解18.四数之和力扣题目链接18. 四数之和 - 力扣LeetCode文章讲解第18题. 四数之和 | 双指针法 | 剪枝去重 | 代码随想录视频讲解难在去重和剪枝| LeetCode18. 四数之和_哔哩哔哩_bilibili三数之和多加一层for循环publicclassSolution{publicIListIListintFourSum(int[]nums,inttarget){//先排序Array.Sort(nums);ListIListintansnewListIListint();for(inti0;inums.Length-3;i){//去重第一个数字if(i0nums[i]nums[i-1]){continue;}for(intji1;jnums.Length-2;j){//去重第二个数字if(ji1nums[j]nums[j-1]){continue;}intleftj1;intrightnums.Length-1;while(leftright){longsum(long)nums[i]nums[j]nums[left]nums[right];if(sumtarget){left;}elseif(sumtarget){right--;}else{//sum targetans.Add(newListint{nums[i],nums[j],nums[left],nums[right]});//去重后两个数字left;right--;while(leftrightnums[left]nums[left-1])left;while(leftrightnums[right]nums[right1])right--;}}}}returnans;}}

相关文章:

代码随想录算法训练营第六天 | Leetcode 454.四数相加 | 383.赎金信 | 15.三数之和 | 18.四数之和

day6 – 哈希表part02 454.四数相加 力扣题目链接:454. 四数相加 II - 力扣(LeetCode)文章讲解:第454题.四数相加II | 哈希表 | map | 统计查找 | 代码随想录视频讲解:学透哈希表,map使用有技巧&#xff…...

YOLO + SubspaceAD:一张良品图,检出所有未知缺陷

YOLO + SubspaceAD:一张良品图,检出所有未知缺陷 当YOLO遇上CVPR 2026子空间建模,工业缺陷检测迎来质变 一、痛点直击:缺陷检测的“三座大山” 第一座山:缺陷样本少,种类严重失衡。 工业生产追求“零缺陷”,导致真实缺陷样本极度稀缺,每十万件产品中往往仅出现3—5件次…...

CMake Converter终极指南:三步实现Visual Studio到CMake的自动化迁移

CMake Converter终极指南:三步实现Visual Studio到CMake的自动化迁移 【免费下载链接】cmakeconverter This project aims to facilitate the conversion of Visual Studio to CMake projects. 项目地址: https://gitcode.com/gh_mirrors/cm/cmakeconverter …...

来画AI漫剧软件2025推荐,创新故事创作工具引领未来

来画AI漫剧软件2025推荐,创新故事创作工具引领未来一、引言随着科技的快速发展,越来越多的创新工具正在改变我们的创作方式。来画AI漫剧软件作为一款集成了人工智能技术的故事创作工具,正逐渐成为创作者们的新宠。本文将从多个维度详细解析来…...

零硬件也能玩!OpenClaw仿生机器人入门全指南:从环境搭建到第一个机械臂抓取项目

很多刚接触仿生机器人的同学,第一次听说OpenClaw,都会被它“仿生龙虾机器人”的名头劝退,觉得这是个只有硬件图纸、没有实操教程的学术项目。我去年第一次接触OpenClaw的时候,光是环境搭建就踩了一周的坑:ROS版本不对、…...

不会做Twitter运营?用赛博云推,一套自动化流程帮你实现涨粉+获客+霸屏

在如今的社交媒体环境中,Twitter(X) 已经成为流量竞争最激烈的平台之一。无论是跨境电商、独立站推广,还是个人IP打造,越来越多的人开始布局Twitter。但很多人在实际操作中都会遇到一个核心问题:做了很久&a…...

HunyuanVideo-Foley部署教程:RTX4090D专属优化版开箱即用完整指南

HunyuanVideo-Foley部署教程:RTX4090D专属优化版开箱即用完整指南 1. 环境准备与快速部署 HunyuanVideo-Foley是一款强大的视频生成与音效生成工具,本教程将指导您在RTX 4090D显卡上快速部署优化版镜像。这个专为24GB显存优化的版本,让您无…...

2026制造企业产品交付周期缩短专项:6款项目管理系统选型分析

核心目标:聚焦制造企业计划协同、跨部门联动、风险前置、行业适配、落地提效五大交付周期核心痛点,梳理6款主流项目管理系统的功能特性、适配场景与核心优劣势,为制造企业结合自身需求精准选型提供客观参考依据。 一、制造企业选型核心维度&…...

7脚 LED数码屏的刷新显示,乱码请指正

我是新手近段时间的工作是点亮7脚LED数码屏,刷新时遇到了困惑请大家帮助指正,在此表示非常感谢。 下面是7脚LED数码屏结构图。 用了7个 case下面是刷新代码switch(ScanPinNum){// ---------------- CASE1: PIN1------------------------case 1: …...

局域网基本原理

1.局域网技术 a.以太网Ethernet b.令牌环 token ring 由IBM公司开发,IEEE802.5就是在此基础上i.工作模式:需要发送数据的时候,需要等待空闲令牌收到后,才能发送,令牌是一种特殊的MAC控制帧 c.FDDI 光纤分布式数据接口i…...

[资源] 【百度网盘 】最终幻想战略版 伊瓦利斯编年史 豪华中文 Build.20688883+全DLC-支持手柄

受太阳与圣印保佑,由双头狮统治的国家――――Ivalice。Ivalice与邻国Ordallia展开“The Fifty Years’ War”却战败。一年后先王病逝,而将要继承王位的王子年仅两岁。此后为争夺监护人的头衔与实权,在“The Fifty Years’ War”立下战功的两…...

出厂自带“缰绳”的AI来了,Hermes Agent正在重新定义智能体

在过去的一年里,AI Agent领域经历了一场又一场热潮,OpenClaw带来的“龙虾热”还没有完全散去,一款名为Hermes Agent的开源智能体框架又迅速闯入开发者视野。发布短短两个月,GitHub星标就突破27000,没有铺天盖地的营销&…...

HTML 5段落

HTML5 段落 (Paragraphs) 学习笔记 在 HTML5 中&#xff0c;段落是文本内容的基本构建块。虽然核心标签 <p> 从 HTML4 继承而来&#xff0c;但 HTML5 在语义化结构、文本流控制以及与语义标签的配合方面有了更明确的规范。一、核心标签&#xff1a;<p> 1. 基本用法…...

别再数据线了!用FastAPI 分钟搭个局域网文件+剪贴板神器志

为 HagiCode 添加 GitHub Pages 自动部署支持 本项目早期代号为 PCode&#xff0c;现已正式更名为 HagiCode。本文记录了如何为项目引入自动化静态站点部署能力&#xff0c;让内容发布像喝水一样简单。 背景/引言 在 HagiCode 的开发过程中&#xff0c;我们遇到了一个很现实的问…...

HTML5 标题

HTML5 标题 (Headings) 学习笔记 HTML5 中的标题元素用于定义文档的层级结构。它们对于文档结构、**SEO&#xff08;搜索引擎优化&#xff09;以及无障碍访问&#xff08;Accessibility&#xff09;**至关重要。 一、标题元素概览 HTML 提供了 6 个级别的标题&#xff0c;从最…...

OpenTiny NEXT 从入门到精通·第 6 篇

OpenTiny NEXT 从入门到精通第 6 篇&#xff1a;架构篇——跨框架集成与微前端实战在企业级前端开发中&#xff0c;多技术栈共存、存量系统迁移、微前端集成是绕不开的三大难题。你可能正在维护一个 Vue 2 的老项目&#xff0c;新业务要用 Vue 3 开发&#xff0c;团队中还有 Re…...

RPA入门,看这篇就够了

一、基础定义&#xff1a;RPA究竟是什么&#xff1f; 机器人流程自动化&#xff08;Robotic Process Automation&#xff0c;简称RPA&#xff09;是一种通过软件程序模拟人类在计算机上的操作行为&#xff0c;依据预设规则自动执行重复性、规则性任务的应用软件技术。简单来说&…...

OpenClaw自动化招聘工具:千问3.5-35B-A3B-FP8筛选简历截图并生成面试问题

OpenClaw自动化招聘工具&#xff1a;千问3.5-35B-A3B-FP8筛选简历截图并生成面试问题 1. 为什么需要自动化招聘工具 去年帮朋友公司处理校招季简历时&#xff0c;我深刻体会到人工筛选的痛点&#xff1a;连续三天熬夜翻阅800多份PDF简历&#xff0c;眼睛酸胀不说&#xff0c;…...

call、apply和bind的原理及使用场景

在JavaScript 中&#xff0c;call、apply 和 bind 是 Function 对象自带的三个方法&#xff0c;这三个方法的主要作用是改变函数中的 this 指向&#xff0c;从而可以达到接花移木的效果 原理&#xff1a; 1、call(thisArgs [,args...]) 该方法可以传递一个thisArgs参数和一个…...

Swoole vs RoadRunner vs PHP-PM:异步I/O配置参数对比表(含内存泄漏率、上下文切换耗时、FD复用率实测)

第一章&#xff1a;Swoole vs RoadRunner vs PHP-PM 异步I/O配置全景概览现代PHP高性能服务化方案中&#xff0c;Swoole、RoadRunner 和 PHP-PM 均通过常驻内存与异步I/O机制突破传统PHP-FPM的阻塞模型&#xff0c;但其实现路径、依赖模型与配置范式存在本质差异。三者均不依赖…...

AI Agent 安全养虾实战:从零基础到专家的阿里云全栈进阶指南

开篇 通关前置认知&#xff1a;为什么AI Agent时代&#xff0c;“安全养虾”是从业者的必修课&#xff1f; 2024-2026年&#xff0c;AI Agent迎来产业级爆发拐点&#xff0c;“养虾”一跃成为横跨数字科技与实体农业两大赛道的全民热词&#xff0c;其背后是两大万亿级市场的核心…...

OPUS编解码器在audio DSP上的移植和应用吨

前言 在使用 kubectl get $KIND -o yaml 查看 k8s 资源时&#xff0c;输出结果中包含大量由集群自动生成的元数据&#xff08;如 managedFields、resourceVersion、uid 等&#xff09;。这些信息在实际复用 yaml 清单时需要手动清理&#xff0c;增加了额外的工作量。 使用 kube…...

C语言-------聚合数据类型

一、结构体1.结构体概念与创建结构体&#xff08;Struct&#xff09;是在编程中用于组合多个相关数据项的复合数据类型&#xff0c;它允许将不同类型的数据&#xff08;如整数、字符、数组&#xff0c;甚至其他结构体&#xff09;聚集在一起&#xff0c;形成一个逻辑上的整体&a…...

一款基于 .NET 开源、跨平台应用程序自动升级组件奈

基础示例&#xff1a;单工作表 Excel 转 TXT 以下是将一个 Excel 文件中的第一个工作表转换为 TXT 的完整步骤&#xff1a; 1. 加载并读取Excel文件 from spire.xls import * from spire.xls.common import * workbook Workbook() workbook.LoadFromFile("示例.xlsx"…...

不用装软件!这款MicroPython浏览器 IDE :让你在手机上也能调试树莓派 Pico亚

1、普通的insert into 如果&#xff08;主键/唯一建&#xff09;存在&#xff0c;则会报错 新需求&#xff1a;就算冲突也不报错&#xff0c;用其他处理逻辑 回到顶部 2、基本语法&#xff08;INSERT INTO ... ON CONFLICT (...) DO (UPDATE SET ...)/(NOTHING)&#xff09; 语…...

彻底搞懂词元(Token)!小白科普,看完再也不懵

不管是用ChatGPT、豆包这类AI工具&#xff0c;还是刷AI相关的科普内容&#xff0c;你一定绕不开一个词——词元&#xff08;Token&#xff09;。 “AI生成内容有词元&#xff08;Token&#xff09;限制”“付费按词元&#xff08;Token&#xff09;计价”“训练AI要先分词元&a…...

中设智控亮相陕西设备管理工作会议,AI赋能方案引领智能运维新变革

2026年3月25日-27日&#xff0c;2026年陕西省设备管理与装备制造工作会议在陕西省汉中市成功召开。本次会议聚焦装备制造业高质量发展与设备管理智能化升级&#xff0c;吸引了众多行业专家与企业代表参会。广东中设智控科技股份有限公司&#xff08;以下简称 “中设智控”&…...

食品行业设备管理系统:筑牢合规追溯防线,规范清洁维护记录

食品行业的核心底线是“安全与合规”&#xff0c;而生产设备作为食品加工的核心载体&#xff0c;其清洁度、运行状态、维护记录直接决定食品质量&#xff0c;更是应对SC、HACCP、ISO22000等合规审计的关键。不同于其他行业&#xff0c;食品生产设备&#xff08;如搅拌罐、灌装机…...

落地即能用!声振温监测部署全流程:设备在线状态监控搭建指南

设备在线状态监控的核心&#xff0c;是通过声振温三大核心数据&#xff0c;捕捉设备隐性故障前兆&#xff0c;实现“早发现、早预警、早处置”&#xff0c;避免非计划停机。而声振温监测的部署&#xff0c;并非简单的“装传感器、连系统”&#xff0c;需遵循科学流程&#xff0…...

ROS2核心概念与架构详解:从零开始机器人操作系统(1)

一、顶级架构一句话总结节点 → DDS通信 → 话题/服务/动作 → 参数 → 工具链 → 机器人应用ROS2&#xff08;Robot Operating System 2&#xff09;是新一代开源机器人操作系统&#xff0c;采用DDS作为通信中间件&#xff0c;去掉了ROS1的Master节点&#xff0c;提供更好的实…...