C++算法第五天
本篇文章继续和大家一起刷算法题

第一题
题目链接
. - 力扣(LeetCode)
题目解析

题目要求:
这是一个连续的子数组
计算子数组内元素的和,若数组内元素的和符合 >= target的值并且该子数组的长度是最短的,则返回该长度
代码原理
原理一:暴力枚举

原理二:滑动窗口

代码编写
对应原理一
class Solution {
public:
int minSubArrayLen(int target, vector<int>& nums) {
int len = INT_MAX;
for(int left = 0; left < nums.size(); left++)
{
int sum = 0;
for(int right = left; right < nums.size(); right++)
{
sum += nums[right];
if(sum >= target)
{
len = min(len, right - left + 1);
break;
}
}
}
if(len == INT_MAX)
{
len = 0;
}
return len;
}
};
这里值得注意的是暴力枚举会超过时间限制,但并不是说这种方法是错误的

对应原理二
class Solution {
public:
int minSubArrayLen(int target, vector<int>& nums) {
int left = 0, right = 0, sum = 0, len = INT_MAX;
while(right < nums.size())
{
sum += nums[right];//进窗口
while(sum >= target)//判断
{//4
len = min(len, right + 1 - left);//更新结果
sum -= nums[left++];//出窗口
}
right++;
}
if(len == INT_MAX)
{
len = 0;
}
return len;
}
};
本题总结
1. 首这个解法叫滑动窗口,本质是同向双指针
2. 使用这个解法的原因是利用了单调性
3.滑动窗口的正确性:利用的单调性,规避了没必要的枚举行为
4.枚举二字算是在博主的文章中第一次出现,那么我也解释枚举是什么意思,枚举就是将每一种情况都一一列举出来
第二题
题目链接
3. 无重复字符的最长子串 - 力扣(LeetCode)
题目解析

题目要求:返回字符串,且字符串内的字符不能有相同
代码原理
方法二:滑动窗口

总而言之,如果nums[right]若与hash表中的字符相同则出窗(即在哈希表中删除)
代码编写
方法二:滑动窗口
class Solution {
public:
int lengthOfLongestSubstring(string s) {
int n = s.size(),len = 0;
int hash[128] = {0};
for(int left = 0, right = 0; right < n; right++)
{
hash[s[right]]++;
while(hash[s[right]] > 1)
{
hash[s[left++]]--;
}
len = max(len, right - left + 1);
}
return len;
}
};
第三题
题目链接
数组中两个字符串的最小距离__牛客网
题目解析


代码原理
思路一:暴力枚举

思路二:贪心算法

代码编写
对应法二
#include <iostream>
#include<string>
using namespace std;
int main() {
int n = 0;
int prev1 = -1, prev2 = -1,min_distance = 0x3f3f3f3f;
cin >> n;
string strs, str1, str2;
cin >> str1 >> str2;
for(int i = 0; i < n; i++)
{
cin >> strs;
if(strs == str1)
{
if(prev2 != -1)
{
min_distance = min(min_distance, i - prev2);
}
prev1 = i;
}
else if(strs == str2)
{
if(prev1 != -1)
{
min_distance = min(min_distance, i - prev1);
}
prev2 = i;
}
}
if(min_distance == 0x3f3f3f3f) cout << -1 << endl;
else cout << min_distance << endl;
return 0;
}
// 64 位输出请用 printf("%lld")
本篇文章的算法题就先讲到这里,我们下期文章再见。

都看到这了,给个三联再走呗,谢谢啦!!!

相关文章:
C++算法第五天
本篇文章继续和大家一起刷算法题 第一题 题目链接 . - 力扣(LeetCode) 题目解析 题目要求: 这是一个连续的子数组 计算子数组内元素的和,若数组内元素的和符合 > target的值并且该子数组的长度是最短的,则返回…...
牛客网剑指Offer-树篇-JZ26 树的子结构
题目 来源:JZ26 树的子结构 描述 输入两棵二叉树A,B,判断B是不是A的子结构。(我们约定空树不是任意一个树的子结构) 假如给定A为{8,8,7,9,2,#,#,#,#,4,7},B为{8,9,2},2个树的结构如下ÿ…...
FFmpeg 4.3 音视频-多路H265监控录放C++开发六,使用SDLVSQT显示yuv文件
使用QT 显示YUV 文件 在最后一帧的时候会不停的显示最后一帧图片。 Vsqtshowyuv.h #pragma once#include <QtWidgets/QWidget> #include "ui_vsqtshowyuv.h" #include <sdl/SDL.h> #include <iostream> #include <fstream> #include <Q…...
Spring 设计模式之适配器模式
Spring 设计模式之适配器模式 适配器模式用到的场景java举例 适配器模式 适配器模式(Adapter Pattern)是一种结构型设计模式,它允许接口不兼容的类一起工作。 其核心思想是通过一个适配器类将不兼容的接口转换成客户端期望的另一个接口&…...
多传感器数字化分析系统
在工业飞速发展的今天,设备的安全稳定运行成为企业高效生产的关键因素。然而,传统的人工巡检方式面临着诸多挑战,如效率低下、漏检误检以及难以精准掌握设备运行状态等。旗晟凭借深厚的技术积累和创新精神,推出了多传感器数字化分…...
Java 基础教学:面向对象编程基础-封装、继承与多态
面向对象编程(OOP)是现代编程的重要范式,Java 语言提供了丰富的 OOP 特性,主要包括封装、继承和多态。本文将详细讲解这三个概念及其实现方式,并提供相应的代码示例。 1. 封装 1.1 概念 封装是将对象的状态…...
Ubuntu环境本地部署DbGate数据库管理工具并实现无公网IP远程访问
文章目录 前言1. 安装Docker2. 使用Docker拉取DbGate镜像3. 创建并启动DbGate容器4. 本地连接测试5. 公网远程访问本地DbGate容器5.1 内网穿透工具安装5.2 创建远程连接公网地址5.3 使用固定公网地址远程访问 前言 本文主要介绍如何在Linux Ubuntu系统中使用Docker部署DbGate数…...
【AI抠图整合包及教程】Meta SAM 2:视觉分割的革命性飞跃
在人工智能的浪潮中,每一次技术的革新都如同一场视觉盛宴,让我们见证着数字时代的变迁。Meta再次以Segment Anything Model 2(SAM 2)引领了图像和视频分割技术的新纪元。作为首个用于实时、可提示的图像和视频对象分割的统一模型&…...
使用语言模型进行文本摘要的五个级别(llm)
视频链接:5 Levels Of LLM Summarizing: Novice to Expert...
ubuntu交叉编译libffi库给arm平台使用
1.下载并解压: 2.生成makefile 编译: make 编译成功: 安装: make install 安装成功 查看安装后的libffi库...
【jvm】空间分配担保策略
目录 1. 说明2. 工作原理2.1 估算新生代存活对象大小2.2 判断老年代的剩余空间2.3 触发Full GC的条件 3. 相关参数与配置3.1 -XX:HandlePromotionFailure3.2 -XX:PretenureSizeThreshold3.3 -XX:MaxTenuringThreshold3.4 -XX:TargetSurvivorRatio 4.作用与意义 1. 说明 1.在Ja…...
iQOO手机怎样将屏幕投射到MacBook?可以同步音频吗?
众所周知,苹果品牌的设备自己有AirPlay的投屏功能,iPhone要投屏到MacBook只要连接同一网络,然后开启AirPlay就可以投屏。但其他品牌的手机没有AirPlay,怎么将手机屏幕投射到MacBook呢? 安卓系统的手机可以使用无线投屏…...
BUU usualCrypt1
查壳,32bit,丢进ida32中进行反编译,简单的不多说,直接进main分析 简单分析,打上注释,没啥好看的,就一个加密函数,加密完后和一个字符串进行比较,由此可以逆推出加密前的字…...
第十七章 标准库特殊设施
17.1 tuple类型 当希望将一些数据合成单一对象,但又不想麻烦地定义一个新数据结构来表示这些数据时,tuple非常有用。tuple是类似pair的模板。 tuple<size_t, size_t, size_t> threeD; //三个成员都设置为0//为每个成员提供初始值 tuple<strin…...
【格言分享】程序员的经典名言解读
上一期文章我们分享了一些程序员的经典名言,每一句都蕴含着深刻的道理。 接下来就给大家一个一个分析一下 这些格言确实捕捉到了编程和软件开发的精髓,每一条都蕴含着丰富的经验和智慧。下面我将逐一解释这些格言,并分享一些我的看法。 C程序员永远不会灭亡。他们只是cast…...
SpringBoot接收LocalDateTime参数
一、通过RequestBody接收 方式1:实体类上加上 JsonFormat,并通过 pattern 属性指定时间格式 public class Time {JsonFormat(pattern "yyyy-MM-dd HH:mm:ss")LocalDateTime localDateTime;JsonFormat(pattern "yyyy-MM-dd")Loca…...
Typora配置GitHub图床--结合PicGo
【当前问题】Typora文档分享时 无法看到本地路径图片 【怎么解决】把文档中的图片设置为 公开链接 【准备工具】 Typora 官网https://typoraio.cn/(购买 / 自寻破解法)GitHub账号 https://github.com/PicGo https://github.com/Molunerfinn/PicGo/relea…...
【书生.浦语实战营】——入门岛
【书生.浦语实战营】——入门岛_第一关_Linux基础 任务分布1. 本地vscode远程连接并进行端口映射端口映射What——何为端口映射How——怎么进行端口映射 2. Linux基础命令touch :创建文件mkdir :创建目录cd:进入 退出 目录pwd :确定当前所在目录cat:可以…...
WPF+MVVM案例实战(十四)- 封装一个自定义消息弹窗控件(下)
文章目录 1、案例效果2、弹窗控件使用1.引入用户控件2、按钮命令实现 3、总结4、源代码获取 1、案例效果 2、弹窗控件使用 1.引入用户控件 打开 Wpf_Examples 项目,在引用中添加用户控件库,在 MainWindow.xaml 界面引用控件库,代码如下&…...
嵌入式——STM32外设应用
STM32 微控制器以其高性能、低功耗和丰富的外设资源,在嵌入式系统设计中得到了广泛应用。以下将详细介绍 STM32 的主要外设及其典型应用,帮助开发者更好地理解和应用这些功能。 1. GPIO(通用输入输出端口) 功能:GPIO…...
DIY智能烛光发饰:用导电缝纫线制作可穿戴电子入门项目
1. 项目概述:当传统手工艺遇上智能微光几年前,我开始接触可穿戴电子,最初的想法很简单:让日常穿戴的物件不只是静态的装饰,而是能与人产生动态交互的“伙伴”。从在衣服上缝几个会亮的LED,到尝试集成传感器…...
仅限本周开放|DeepSeek Chat V3.2功能测试黄金 checklist(含17个边界Case+响应时延基线数据)
更多请点击: https://intelliparadigm.com 第一章:DeepSeek Chat V3.2功能测试黄金 checklist 发布说明 DeepSeek Chat V3.2 已正式面向开发者开放灰度测试,本次版本聚焦多模态理解增强、长上下文稳定性优化及企业级安全策略集成。为保障测试…...
小学生如何学好GESP
一、按年龄段科学规划学习路径 1. 6–9岁(小学低年级):重在逻辑启蒙,不急于学代码 A、核心任务:培养计算思维、问题拆解、条件判断等能力。 B、推荐方式: (1)、…...
全网首份DeepSeek-MMLU交叉验证报告:在真实业务场景中,高分≠高可用——5类典型失败案例与鲁棒性加固方案
更多请点击: https://intelliparadigm.com 第一章:DeepSeek-MMLU基准测试成绩全景概览 MMLU(Massive Multitask Language Understanding)是评估大语言模型跨学科知识广度与推理能力的关键基准,涵盖57个学科领域&#…...
RMSNorm:均方根归一化总结
RMSNorm:均方根归一化总结 1. RMSNorm 是什么? RMSNorm 的全称是 Root Mean Square Normalization,中文可以叫:均方根归一化它是 Transformer 大模型中常用的一种归一化方法,例如 LLaMA、Qwen、DeepSeek、Gemma 等模型…...
用STC89C52单片机+ADC0832做个智能台灯:手把手教你实现PWM调光和光敏自动控制
从零打造智能台灯:STC89C52与ADC0832的完美结合 记得第一次在宿舍熬夜赶项目时,刺眼的台灯总让我眼睛酸涩不已。那时我就在想,如果能有一个能自动调节亮度的台灯该多好。今天,我们就用STC89C52单片机和ADC0832模数转换器ÿ…...
5个实战案例:使用Promises/A+规范解决复杂异步编程难题
5个实战案例:使用Promises/A规范解决复杂异步编程难题 【免费下载链接】promises-spec An open standard for sound, interoperable JavaScript promises—by implementers, for implementers. 项目地址: https://gitcode.com/gh_mirrors/pr/promises-spec P…...
如何在安卓设备上安装和配置HMCL-PE:Minecraft Java版移动启动器终极指南
如何在安卓设备上安装和配置HMCL-PE:Minecraft Java版移动启动器终极指南 【免费下载链接】HMCL-PE Hello Minecraft! Launcher for Android 项目地址: https://gitcode.com/gh_mirrors/hm/HMCL-PE 想在手机上畅玩Minecraft Java版却不知从何开始?…...
下载视频不如用Via,一分都不花
找了很长时间,没想到竟然这么简单,为啥早没发现呢! 工具的名称叫Via浏览器是个App,没错在安卓手机或平板运行的工具。 缺点:pc下用不了,有些视频下不了,如爱奇艺等。苹果手机是否能用不知道,自己试吧。 优点:操作方便、简单,即使你是小白也能熟练操作。免费,一分…...
华硕游侠2-RX键盘多功能滚轮自定义M失效的解决方案
新买了一块游侠2 rx键盘,想着用自定义滚轮方便打开常用程序,但是发现在Armoury Crate中设置后不起作用,网上解决方案伤筋动骨,得不偿失,有一定风险。 经测试,自定义滚轮能正常执行宏定义,只是对…...
