day02-数组part02

一、长度最小的子数组(滑动窗口)

leetcode 209 长度最小子数组

这道题的核心思想就是使用滑动窗口,滑动窗口三板斧:

  1. 初始位置i
  2. 滑动窗口长度j-i+1
  3. 结束位置j

我们在写代码时是通过for循环来控制结束位置j,而初始位置i是在满足条件的情况下才向前移动的

class Solution {
public:int minSubArrayLen(int target, vector<int>& nums) {int i=0,j=0;//i是窗口起始位置,j是终止位置int result = INT32_MAX; //因为要找到最小的,如果初始成0,那0永远是最小的int subLength = 0; //子数组长度int sum = 0;for(j=0;j<nums.size();j++){sum += nums[j]; //一直叠加到终止位置while(sum >= target){ //满足条件后要判断此时字串长度是否更小,同时移动起始位置isubLength = j-i+1;if(subLength < result) result = subLength;sum -= nums[i];//i指针移动,sum减去一个值i++;}}return result==INT32_MAX ? 0:result;}
};

二、模拟 - 螺旋矩阵Ⅱ

leetcode 59 螺旋矩阵

这道题目就是要模拟按照顺时针画矩阵的过程

  1. 填充上行从左到右
  2. 填充右列从上到右
  3. 填充下列从右到左
  4. 填充左列从下到上

同时需要注意的是每一行(列)的处理范围要保持一致——左闭右开

我们首先要确定总共要绕多少圈(loop),接着就在每一圈内顺时针填充行列,一定要注意边界处理条件

class Solution {
public:vector<vector<int>> generateMatrix(int n) {vector<vector<int>> result(n,vector<int>(n,0));int loop = n/2; //所要走的圈数int startx = 0,starty = 0; //每一圈开始的起始位置int mid = n/2; //中间值(在n为奇数时需要特殊处理)int offset = 1; //用于处理每一圈的边界int i,j;int count = 1;//向矩阵中填的数while(loop){i = startx;j = starty;//四个for循环模拟for(j;j<n-offset;j++){ //模拟上行从左到右result[i][j] =  count;count++;}for(i;i<n-offset;i++){//模拟右列从上到下result[i][j] = count++;}for(j;j>starty;j--){//模拟下行从右到左(注意边界条件,同时这里循环变量刚好从上面结束的j开始)result[i][j] = count++;}for(i;i>startx;i--){//模拟左列从下到上result[i][j] = count++;}startx++;starty++;offset++; //表示边界的结束位置要少一位(因为下一处绕的圈变小了)loop--;}//处理n是边界的情况if(n%2 != 0){result[mid][mid] = count;}return result;}
};

三、一维前缀和

题目

前缀和用来求解区间之和,一维指的是求解的是一维数组的前缀和。

前缀和的核心思想就是设置了一个前缀和数组sum

sum数组初始化如下:

  • sum[0] = Array[0]
  • i>0,sum[i] = sum[i-1] + Array[i]

接下来就可以利用sum数组来求解数组区间[a,b]的和,利用下面的公式计算:

  • 当a = 0 时 , result = sum[b]
  • 当a>0时,result = sum[b] - sum[a-1]
#include<bits/stdc++.h>
using namespace std;int main(){int n,i;int a,b;int result;cin>>n;vector<int>Array(n);vector<int>sum(n,0);for(i=0;i<n;i++){cin>>Array[i];}sum[0] = Array[0];for(i=1;i<n;i++){sum[i] = sum[i-1] + Array[i];}while(cin>>a>>b){if(a==0) result = sum[b];else result = sum[b] - sum[a-1]; printf("%d\n",result);}
}

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。
如若转载,请注明出处:http://www.pswp.cn/diannao/90733.shtml
繁体地址,请注明出处:http://hk.pswp.cn/diannao/90733.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

天爱验证码深度解析:从原理到实战,构建 Web 安全新防线

在网络安全日益严峻的当下&#xff0c;验证码作为抵御自动化攻击的重要屏障&#xff0c;其性能与可靠性直接关系到系统的安全稳定。天爱验证码&#xff08;TIANAI CAPTCHA&#xff09;作为国内优秀的开源行为验证码解决方案&#xff0c;凭借独特的技术优势&#xff0c;在电商、…

软考(软件设计师)软件工程-软件质量,软件测试,McCabe圈复杂度

软件质量 ISO/IEC 9126 是软件工程领域的经典质量模型&#xff0c;于1991年首次发布&#xff0c;2001年更新后成为软件产品质量评估的国际标准。其核心贡献是将抽象的“质量”概念分解为可度量、可管理的特性体系。以下是深度解析&#xff08;2023年行业实践视角&#xff09;&a…

CentOS7环境安装包部署并配置MySQL5.7

卸载MySQL卸载MySQL5.71、关闭MySQL5.7服务service mysqld stop2、查看MySQL安装rpm -qa|grep -i mysqlmysql-community-libs-5.7.35-1.el7.x86_64mysql-community-libs-compat-5.7.35-1.el7.x86_64mysql-community-common-5.7.35-1.el7.x86_64mysql57-community-release-el7-1…

1-Git安装配置与远程仓库使用

Git安装配置与远程仓库使用 1. Git 下载与安装 ① 进入Git 官网 https://git-scm.com/ ② 选择合适系统版本下载&#xff0c;本文以windows为例进行下载 当前最新版本为 2.50.1 &#xff0c;浏览器默认下载很慢&#xff0c;用迅雷比较快 ③ 安装Git 我安装在D盘 等待完…

开源“具身大脑” 实现不同机器人群体协作-RoboBrain

开源“具身大脑” 实现不同机器人群体协作-RoboBrain 具身大小脑协作框架RoboOS与开源具身大脑RoboBrain&#xff0c;实现跨场景多任务轻量化快速部署与跨本体协作&#xff0c;推动单机智能迈向群体智能&#xff0c;为构建具身智能开源统一生态加速场景应用提供底层技术支持。支…

【笔记】训练步骤代码解析

目录 config参数配置 setup_dirs创建训练文件夹 load_data加载数据 build_model创建模型 train训练 记录一下训练代码中不理解的地方 config参数配置 config {data_root: r"D:\project\megnetometer\datasets\WISDM_ar_latest\organized_dataset",train_dir: t…

Java填充Word模板

文章目录前言一、设置word模板普通字段列表字段复选框二、代码1. 引入POM2. 模板放入项目3.代码实体类工具类三、测试四、运行结果五、注意事项前言 最近有个Java填充Word模板的需求&#xff0c;包括文本&#xff0c;列表和复选框勾选&#xff0c;写一个工具类&#xff0c;以此…

【MYSQL8】springboot项目,开启ssl证书安全连接

文章目录一、开启ssl证书1、msysql部署时默认开启ssl证书2、配置文件3、创建用户并指定ssl二、添加Java信任库1、使用 keytool 导入证书2、验证证书是否已导入三、修改连接配置一、开启ssl证书 1、msysql部署时默认开启ssl证书 可通过命令查看&#xff1a; SHOW VARIABLES L…

Telegraf vs. Logstash:实时数据处理架构中的关键组件对比

在现代数据基础设施中&#xff0c;Telegraf 和 Logstash 是两种广泛使用的开源数据收集与处理工具&#xff0c;但它们在设计目标、应用场景和架构角色上存在显著差异。本文将从实时数据处理架构、时序数据库集成、消息代理支持等方面对比两者的核心功能&#xff0c;并结合实际应…

Vue Vue-route (4)

Vue 渐进式JavaScript 框架 基于Vue2的学习笔记 - Vue-route 编程式导航和几种路由 目录 编程式导航 详情组件 创建组件 设置路由 电影列表 传参 另一种方式 动态路由 命名路由 别名 总结 编程式导航 点击电影列表 跳转电影详情 详情组件 创建组件 在views中创…

存在两个cuda环境,在conda中切换到另一个

进入 openmmlab 环境 conda activate openmmlab 设置环境变量为 CUDA 12.4&#xff08;只影响当前 shell 会话&#xff09; export PATH/usr/local/cuda-12.4/bin:PATHexportLDLIBRARYPATH/usr/local/cuda−12.4/lib64:PATH export LD_LIBRARY_PATH/usr/local/cuda-12.4/lib64:…

Django 视图(View)

1. 视图简介 视图负责接收 web 请求并返回 web 响应。视图就是一个 python 函数,被定义在 views.py 中。响应可以是一张网页的 HTML 内容、一个重定向、一个 404 错误等等。响应处理过程如下图: 用户在浏览器中输入网址:www.demo.com/1/100Django 获取网址信息,去除域名和端…

HarmonyOS基础概念

一、OpenHarmony、HarmonyOS和Harmony NEXT区别OpenHarmony是由开放原子开源基金会&#xff08;OpenAtom Foundation&#xff09;孵化及运营的开源项目&#xff0c;开放原子开源基金会由华为、阿里、腾讯、百度、浪潮、招商银行、360等十家互联网企业共同发起组建。目标是面向全…

spark3 streaming 读kafka写es

1. 代码 package data_import import org.apache.spark.sql.{DataFrame, Row, SparkSession, SaveMode} import org.apache.spark.sql.types.{ArrayType, DoubleType, LongType, StringType, StructField, StructType, TimestampType} import org.apache.spark.sql.functions._…

【跟着PMP学习项目管理】每日一练 - 3

1、你是一个建筑项目的项目经理。电工已经开始铺设路线,此时客户带着一个变更请求来找你。他需要增加插座,你认为这会增加相关工作的成本。你要做的第一件事? A、拒绝做出变更,因为这会增加项目的成本并超出预算 B、参考项目管理计划,查看是否应当处理这个变更 C、查阅…

CentOS 安装 JDK+ NGINX+ Tomcat + Redis + MySQL搭建项目环境

目录第一步&#xff1a;安装JDK 1.8方法 1&#xff1a;安装 Oracle JDK 1.8方法 2&#xff1a;安装 OpenJDK 1.8第二步&#xff1a;使用yum安装NGINX第三步&#xff1a;安装Tomcat第四步&#xff1a;安装Redis第五步&#xff1a;安装MySQL第六步&#xff1a;MySQL版本兼容性问题…

如何设计一个登录管理系统:单点登录系统架构设计

关键词&#xff1a;如何设计一个登录管理系统、登录系统架构、用户认证、系统安全设计 &#x1f4cb; 目录 开篇&#xff1a;为什么登录系统这么重要&#xff1f;整体架构设计核心功能模块安全设计要点技术实现细节性能优化策略总结与展望 开篇&#xff1a;为什么登录系统这么…

论迹不论心

2025年7月11日&#xff0c;16~26℃&#xff0c;阴 紧急不紧急重要 备考ing 备课不重要 遇见&#xff1a;免费人格测试 | 16Personalities&#xff0c;下面是我的结果 INFJ分析与优化建议 User: Anonymous (隐藏) Created: 2025/7/11 23:38 Updated: 2025/7/11 23:43 Exported:…

【面板数据】省级泰尔指数及城乡收入差距测算(1990-2024年)

对中国各地区1990-2024年的泰尔指数、城乡收入差距进行测算。本文参考龙海明等&#xff08;2015&#xff09;&#xff0c;程名望、张家平&#xff08;2019&#xff09;的做法&#xff0c;采用泰尔指数测算城乡收入差距。参考陈斌开、林毅夫&#xff08;2013&#xff09;的做法&…

http get和http post的区别

HTTP GET 和 HTTP POST 是两种最常用的 HTTP 请求方法&#xff0c;它们在用途、数据传输方式、安全性等方面存在显著差异。以下是它们的主要区别&#xff1a;1. 用途GET&#xff1a;主要用于请求从服务器获取资源&#xff0c;比如获取网页内容、查询数据库等。GET 请求不应该用…