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

每日一题day1(Leetcode 76最小覆盖子串)

1.题目解析1.该题“讲人话”就是在一个字符串s中找到一个最短的能够涵盖子串所有字符的子串2.解法解法1暴力枚举hash表classSolution{public:stringminWindow(string s,string t){intms.size();intnt.size();if(mn)return;// 解决实例3的特殊情况unordered_mapchar,intneed;// 统计t中的字符需要的次数for(autoc:t){need[c];}intrequiredneed.size();// 记录字符种类intlenINT_MAX;intstart0;// 记录子串开始位置为后续返回字符串奠定基础for(inti0;im;i){intmatched0;unordered_mapchar,intwindow;for(intji;jm;j){charcs[j];if(need.count(c)){// 筛除不必要的元素window[c];// 记录子串中字符出现次数if(window[c]need[c])matched;// 达到目标}if(matchedrequired){intcurrentlenj-i1;if(currentlenlen){lencurrentlen;starti;// 更新位置}break;}}}returnlenINT_MAX?:s.substr(start,len);}};虽然这种解题方法容易想但是作为一道困难题是绝对不可能让你暴力O(n^2)过的这个时候我们就需要在暴力的基础上进行优化我们此处可以选择使用滑动窗口的方式对该问题进行优化解法2滑动窗口手动hashclassSolution{public:stringminWindow(string s,string t){inthash1[128]{0};// 统计t内字符出现的次数intkinds0;//统计有效字符个数for(autoch:t){if(hash1[ch]0)kinds;}inthash2[128]{0};intminlenINT_MAX,begin-1;for(intleft0,right0,count0;rights.size();right){charins[right];if(hash2[in]hash1[in])//进窗口加维护countcount;while(countkinds){//判断if(right-left1minlen){//更新结果minlenright-left1;beginleft;}charouts[left];//出·窗口维护countif(hash2[out]--hash1[out])count--;}}if(begin-1)return;elsereturns.substr(begin,minlen);}};

相关文章:

每日一题day1(Leetcode 76最小覆盖子串)

1.题目解析 1.该题“讲人话”就是在一个字符串s中找到一个最短的能够涵盖子串所有字符的子串 2.解法 解法1&#xff08;暴力枚举hash表&#xff09; class Solution { public:string minWindow(string s, string t) {int m s.size();int n t.size();if (m < n)return &quo…...

从零部署RKNN模型:在Ubuntu22.04上搭建Python3.8虚拟环境与RKNN Toolkit2-1.5.2开发环境

1. 环境准备与Python 3.8安装 刚拿到一台全新的Ubuntu 22.04系统时&#xff0c;你会发现默认安装的Python版本可能是3.10。但RKNN Toolkit2-1.5.2对Python 3.8的支持最稳定&#xff0c;这是我踩过几次坑后得出的经验。先别急着创建虚拟环境&#xff0c;我们需要确保系统基础环境…...

魔兽争霸3现代难题终结者:WarcraftHelper一站式解决方案

魔兽争霸3现代难题终结者&#xff1a;WarcraftHelper一站式解决方案 【免费下载链接】WarcraftHelper Warcraft III Helper , support 1.20e, 1.24e, 1.26a, 1.27a, 1.27b 项目地址: https://gitcode.com/gh_mirrors/wa/WarcraftHelper 还在为魔兽争霸3在现代电脑上的各…...

全网通用版|2026 年财务培训机构优缺点分析与选择指南(附选型标准)

2026 年财务行业向复合型、数字化、合规化转型&#xff0c;会计培训市场 2025 年规模已突破320 亿元&#xff08;来源&#xff1a;《2025 中国财经教育行业发展报告》&#xff09;&#xff0c;预计 2030 年超900 亿元。财务从业者与企业选型培训机构&#xff0c;直接决定职业晋…...

DotNetPy:现代.NET 与 Python 互操作 实战指南撼

我为什么会发出这个疑问呢&#xff1f;是因为我研究Web开发中的一个问题时&#xff0c;HTTP请求体在 Filter&#xff08;过滤器&#xff09;处被读取了之后&#xff0c;在 Controller&#xff08;控制层&#xff09;就读不到值了&#xff0c;使用 RequestBody 的时候。 无论是字…...

014、搭建你的第一个神经网络(使用Keras/TensorFlow)

昨天有个刚转行的同事跑来找我,屏幕上是个经典的MNIST手写数字识别模型,训练集准确率冲到99%,验证集死活卡在87%。“明明没报错,为什么泛化这么差?”他指着损失曲线里那条越拉越大的缝隙问我。我扫了眼代码,发现他在model.fit()里没切验证集,自己手动拆的数据又忘了做归…...

5.3 风险模型介入:利用Barra CNE5进行因子纯化

5.3 风险模型介入&#xff1a;利用Barra CNE5进行因子纯化 一、引言&#xff1a;为什么需要“纯净”的Alpha&#xff1f; 在上一节中&#xff0c;我们学会了如何将几十个相关因子合成为少数几个复合因子。但这还不够。当你构建的策略在回测中表现优异时&#xff0c;必须回答一…...

sqlite3_prepare_v2 与 sqlite3_exec 在 SQLite 中的核心区别

sqlite3_prepare_v2 与 sqlite3_exec 在 SQLite 中的核心区别如下&#xff1a;性能对比 | 特性 | sqlite3_exec | sqlite3_prepare_v2 | |-------------------|-------------------------------------|--------------------------…...

FlinkCDC实战:利用skipped.operations参数灵活过滤数据变更事件

1. 为什么需要过滤数据变更事件&#xff1f; 在实际的数据同步场景中&#xff0c;我们经常会遇到这样的需求&#xff1a;只需要处理某几种类型的数据变更&#xff0c;而忽略其他类型的变更。比如有些系统只需要关注新增数据&#xff0c;对更新和删除操作不感兴趣&#xff1b;有…...

面试官:说说JVM的栈上分配、TLAB、PLAB有啥区别?

我们在学习 G1 回收器的时候&#xff0c;一般我们都会接触到 TLAB 和 PLAB 这两个术语。它们都是为了提高内存分配效率而存在的&#xff0c;但它们和栈上分配有什么区别呢&#xff1f;今天&#xff0c;就让树哥带着大家盘一盘。栈上分配稍微了解过 Java 虚拟机内存结构的同学都…...

从RNN到Mamba:我的序列建模踩坑史与状态空间模型(SSM)入门指南

从RNN到Mamba&#xff1a;我的序列建模踩坑史与状态空间模型(SSM)入门指南 记得第一次接触序列建模是在2018年&#xff0c;当时为了完成一个股票价格预测项目&#xff0c;我整夜调试着那个总是梯度爆炸的LSTM模型。五年后的今天&#xff0c;当我用Mamba处理同样长度的时序数据时…...

消息队列学习计划 - 阶段三:面试高频问题

消息队列学习计划 - 阶段三&#xff1a;面试高频问题目标&#xff1a;准备所有 MQ 相关面试问题&#xff0c;覆盖基础到进阶&#xff0c;能应对字节/腾讯等大厂面试 预计周期&#xff1a;1 周&#xff0c;每天 1-2 小时&#xff08;以记忆和模拟为主&#xff09;面试问题分类类…...

阿里云专有云网络架构

一、 网络设备角色详解&#xff08;基于阿里云飞天网络架构&#xff09; 结合 v3.18.6r 版本特性&#xff0c;对图中各缩写设备进行标准化定义&#xff1a;设备缩写全称在单元Region中的核心职责1659台规模下的配置建议NCNode Controller物理服务器节点。包含计算节点&#xff…...

SwitchHosts实战指南:图形化界面下的Hosts文件高效管理技巧

1. 为什么你需要SwitchHosts来管理Hosts文件 每次调试网站或者切换测试环境时&#xff0c;手动修改Hosts文件就像用螺丝刀修电脑——既原始又低效。我见过不少同事因为手滑输错一个IP地址&#xff0c;导致整个下午都在排查"为什么网站打不开"。更糟的是&#xff0c;当…...

从LLM到VLM再到VLA:小白程序员必看的大模型学习路径(值得收藏!)

从LLM到VLM再到VLA&#xff1a;小白程序员必看的大模型学习路径&#xff08;值得收藏&#xff01;&#xff09; 本文梳理了通用人工智能&#xff08;AGI&#xff09;的发展路径&#xff0c;从单模态大语言模型&#xff08;LLM&#xff09;演变为多模态视觉-语言模型&#xff08…...

2026奇点大会AIAgent控制框架深度拆解(ROS 3.0+LLM-Os融合架构首次公开,仅限首批参会者获取的SDK已泄露)

第一章&#xff1a;2026奇点智能技术大会&#xff1a;AIAgent机器人控制 2026奇点智能技术大会(https://ml-summit.org) 实时多模态指令解析架构 大会现场演示的AIAgent控制系统采用分层语义解耦设计&#xff0c;将自然语言指令&#xff08;如“绕过障碍物&#xff0c;拾取红…...

【数据分析】【SQL】实战演练——从sqlzoo习题到业务场景(戴师兄风格)

1. 从sqlzoo习题到业务场景的思维转换 第一次接触sqlzoo平台时&#xff0c;我完全被它精巧的习题设计惊艳到了。这个平台把枯燥的SQL语法练习&#xff0c;包装成了探索世界数据库的冒险游戏。但真正让我开窍的&#xff0c;是后来在电商公司做数据分析时&#xff0c;突然发现那些…...

APP Inventor蓝牙APP制作:从零到一打造专属遥控器

1. 为什么选择APP Inventor制作蓝牙遥控器 最近在折腾一台自制的蓝牙小车&#xff0c;发现市面上的通用蓝牙调试工具根本不够用。要么功能太简单&#xff0c;要么界面丑得没法看。作为一个对用户体验有强迫症的人&#xff0c;我决定自己动手做一个专属遥控APP。经过一番调研&am…...

AI Agent岗位技术八股:高频问题与答案

这些实际上更像工程难题&#xff0c;公司愿意给30k月薪的原因就在这里&#xff0c;Agent研发不是玩具技能人&#xff0c;是能把玩具变成生产力的人。这环节最直接有效的策略就是跟着项目完整走一遍&#xff0c;如果你无从下手&#xff0c;趁着有大佬带队&#xff0c;你直接跟着…...

Topology:专业级网络拓扑图绘制与可视化解决方案

Topology&#xff1a;专业级网络拓扑图绘制与可视化解决方案 【免费下载链接】topology 项目地址: https://gitcode.com/gh_mirrors/top/topology 在当今复杂的网络环境中&#xff0c;清晰直观的网络拓扑图已成为网络工程师和运维人员不可或缺的助手。Topology作为一款…...

基于微信小程序的校园/体育馆预约系统,支持人脸识别签到+动态二维码,附前端+后端源码

获取方式&#xff1a;关注CSDN博客&#xff0c;私信回复「场馆预约」一、项目背景2026年&#xff0c;体育场馆、会议室、培训教室等线下场地的预约需求爆发式增长&#xff0c;但传统电话/线下登记方式存在信息不同步、时间冲突难排查、管理效率低三大痛点。本文手把手教你用Uni…...

抖音视频批量下载技术实战:douyin-downloader架构设计与应用指南

抖音视频批量下载技术实战&#xff1a;douyin-downloader架构设计与应用指南 【免费下载链接】douyin-downloader A practical Douyin downloader for both single-item and profile batch downloads, with progress display, retries, SQLite deduplication, and browser fall…...

UE5跨平台开发实录:如何用Windows电脑给Linux玩家打包游戏?

UE5跨平台开发实战&#xff1a;Windows环境下为Linux平台打包的完整指南 当游戏开发团队需要同时面向Windows和Linux平台发布时&#xff0c;如何在Windows开发环境中高效完成Linux平台的打包工作&#xff1f;本文将深入探讨UE5&#xff08;5.3.2版本&#xff09;的跨平台编译全…...

解锁多光谱图像数据集:从入门到精通的实战指南

1. 多光谱图像数据集入门指南 第一次接触多光谱数据时&#xff0c;我被那些五颜六色的波段图搞得晕头转向。记得当时为了搞明白WorldView-3卫星的8个波段分别代表什么&#xff0c;整整花了两天时间查资料。现在回头看&#xff0c;其实掌握多光谱数据并没有想象中那么难&#xf…...

全球太阳辐射与风力数据资源全解析:从免费到付费的五大平台对比

1. 科学数据中心&#xff1a;免费但有限的基础选择 科学数据中心&#xff08;https://www.casdc.cn/&#xff09;是国内较为知名的科研数据共享平台&#xff0c;主要面向学术研究领域提供气象、环境等数据服务。实测下来&#xff0c;它的太阳辐射数据以CSV和NetCDF格式为主&…...

从理论到实践:傅里叶变换、DFT与FFT的数学原理与代码实现

1. 傅里叶变换&#xff1a;从物理现象到数学表达 第一次接触傅里叶变换时&#xff0c;我盯着那堆积分符号看了整整一个下午。直到某天深夜调试音频处理程序时突然顿悟&#xff1a;原来它就像音乐的"成分分析仪"。想象你面前有杯混合果汁&#xff0c;傅里叶变换能告诉…...

建议收藏:机器学习与深度学习的区别是什么?如何选择研究方向?

建议收藏&#xff1a;机器学习与深度学习的区别是什么&#xff1f;如何选择研究方向&#xff1f; 标签&#xff1a;#机器学习、#深度学习、#人工智能、#计算机视觉、#自然语言处理、#数据分析、#ai ### 一、企业招聘角度拆解&#xff1a;机器学习 vs 深度学习&#xff0c;岗位…...

jmeter进行数据库读取预处理转换数组传入

Groovy 脚本实现import groovy.json.JsonOutput// 定义一个通用的转换函数&#xff1a;将 JDBC 变量转为数字列表 def convertJdbcToList { prefix ->def count vars.get(prefix "_#")if (count null || count.toInteger() 0) return []int n count.toInteg…...

揭秘AI Agent:不只是ChatGPT,还能自主干活的AI神器!

AI Agent是一种有目标、会思考、能自主调用工具完成任务的AI。它区别于大语言模型聊天助手&#xff0c;具备记忆、自主规划和行动能力。Agent类型多样&#xff0c;如编程、个人助理、内容生成和通用类型等。运行模式主要包括ReAct&#xff08;思考行动&#xff09;和Plan-and-E…...

程序员转行大模型开发:高薪风口!4大方向+90天学习路线助你月薪30K+

程序员转行到大模型开发领域&#xff0c;可以根据个人兴趣和职业规划选择不同的方向。以下是几个推荐的方向、推荐原因以及学习路线&#xff1a;1. 自然语言处理&#xff08;NLP&#xff09;工程师 推荐原因&#xff1a; NLP是AI大模型应用最广泛的领域之一&#xff0c;随着聊天…...