算法训练day2

news/2024/11/28 21:45:39/文章来源:https://www.cnblogs.com/22tomatoer/p/18575305

209.长度最小的子数组https://leetcode.cn/problems/minimum-size-subarray-sum/: 给定一个含有n个正整数的数组和一个正整数target。找出该数组中满足其总和大于等于target的长度最小的子数组[nums_l, nums_{l+1}, ..., nums_{r-1}, nums_r],并返回其长度。如果不存在符合条件的子数组,返回0
(1)暴力求解法:利用两个循环,分别遍历子列的起始位置和终止位置;若检查到和>= target的子列,将其长度记为len;实时更新满足条件的最短子列长result。

class Solution {
public:int minSubArrayLen(int target, vector<int>& nums) {int sum = 0, len = 0, s = nums.size()+10;for (int i = 0; i < nums.size(); i++){sum = 0;for (int j = i; j <nums.size(); j++){sum += nums[j];if (sum >= target) {len = j-i+1;break; }else len = nums.size()+10;}if (s > len) s = len;}return s == nums.size() + 10 ? 0 : s;}
};

时间复杂度:O(n^2),这导致当n很大时超出时间限制;
空间复杂度:O(1)
(2)移动窗口解法:利用一个for循环遍历窗口终止位置,以其和sum是否大于target作为元素是否在窗口中的依据。若sum小于target,向后移动窗口终止位置;若sum大于target,向后移动窗口起始位置。注意移动时和sum的变化;并实时记录和比较子列长度。

class Solution {
public:int minSubArrayLen(int target, vector<int>& nums) {int sum = 0, sublenth = 0, result = INT32_MAX;int i = 0; //star indexfor (int j = 0; j < nums.size(); j++){sum += nums[j];while(sum >= target){sublenth = j - i + 1;result = result < sublenth ? result : sublenth;sum -= nums[i++]; // 这里体现出滑动窗口的精髓之处,不断变更icontinue;}}return result == INT32_MAX ? 0 : result;}
};

空间复杂度:O(n)
时间复杂度:O(1)
(3)解题困难:①不能准确判断移动窗口的起始位置i和终止位置j的设置;②尝试先固定子数组长度,再找满足和条件的子数组,最终还是要用两个循环。

59.螺旋矩阵https://leetcode.cn/problems/spiral-matrix-ii/: 给你一个正整数n,生成一个包含1n^2所有元素,且元素按顺时针顺序螺旋排列的n x n正方形矩阵matrix
(1)自我思路:n为奇数时有中心,为偶数时只有外圈;一圈四边,每边的元素数目只计算左闭右开区间内的元素。
(2)循环求解:

class Solution {
public:vector<vector<int>> generateMatrix(int n) {std::vector<std::vector<int>> arr(n, std::vector<int>(n,0));int loop = n / 2; //记录要填充圈数,n为奇数时还需要单独处理中间位置int startx = 0, starty = 0; // 定义每循环一个圈的起始位置int mid = n/2;//记录中间位置int offset = 1;int count = 1;int i, j;while (loop--){i = startx; j = starty;for (j; j < n - offset; j++){ //j从0变到n-offset,n-offset未进入循环arr[i][j] = count++;}for (i; i < n - offset; i++) {//j从0变到n-1arr[i][j] = count++;}for (; j > startx; j--){ //j从n-offset 变到startxrr[i][j] = count++;}for (; i > starty; i--){ //i从n-offset 变到startyarr[i][j] = count++;}// 第二圈开始的时候,起始位置要各自加1startx++;starty++;// offset 控制每一圈里每一条边遍历的长度offset += 1;}if (n % 2) arr[mid][mid] = n*n;return arr;}
};

时间复杂度:O(n^2)
空间复杂度:O(1)
(3)主要困难:误用行列乘积给元素赋值;区间端点i与j的设置;
(4)收获:自增运算符有共同效果和细微区别。① 后缀自增:i++ 会先返回 i 的当前值,然后 i 的值增加1。② 前缀自增:++i 会先将 i 的值增加1,然后返回 i 的新值。例如

int i = 1;
int a = i++; // a = 1, i = 2
int b = ++i; // i = 3, b = 3

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

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

相关文章

【java编程】Unsafe 类

Unsafe 类不是一个 ClassLoader, 但是为什么要在本篇文章提起, 其实是因为该类可以进行注入恶意类到 JVM 中. Unsafe 类简介 sun.misc.Unsafe 类是一个提供底层、不安全的操作,比如直接内存访问、线程调度、原子操作等功能的工具类。 这个类主要被Java内部库使用,比如Java的…

山体落石泥石流自动监测摄像机

山体落石泥石流自动监测摄像机捕获的图像数据将对图像进行分析,山体落石泥石流自动监测摄像机识别出山体的位移、裂缝、滑坡等异常现象。算法的训练需要大量的山体图像数据,包括正常和异常状态的图像,以确保其识别的准确性。一旦AI系统识别出山体失稳的迹象,它会立即触发报…

【java编程】Xalan ClassLoader

Xalan 是 Java 中用于操作 XML 的一个库,它是 Apache XML 项目的一部分,主要用于将 XSLT(Extensible Stylesheet Language Transformations)转换为可执行代码,从而实现XML文档的转换。 XSLT 的理解 当然了, 我们先理解该模块如何使用之后, 我们再研究它的妙用, XSLT 说白了…

[游记]CSP2024 游记

这是一篇迟到的游记,为什么呢?因为作者已经成为文化课选手了。 Day-1 晚上 \(6:00\) 到了宾馆,在路上准备了一下面基事宜。在车上昏昏沉沉,结果下了车精神抖擞了。 简单布置之后开始摆烂,这是符合考前规范的好事。某游戏连跪十五局。rp -- 。我希望这是给我第二天攒 rp。 …

[笔记]动态规划优化(斜率优化,决策单调性优化)

本文主要记录某些动态规划思路及动态规划优化。 首先先把以前写过的斜率优化祭出来。 斜率优化 \(\text{P5017 [NOIP2018 普及组] 摆渡车}\) 经典例题。 设 \(f_i\) 表示最后班车在 \(i\) 时刻发车,所有人等待时间和的最小值。(这里的所有人是指到达时刻小于等于 \(i\) 的所有…

基于Java+SpringBoot+Mysql实现的点卡各种卡寄售平台功能设计与实现一

后台功能:寄售管理、提现管理、订单管理、认证管理、公告管理、用户管理等。 该系统总共21张表,代码整洁,每个功能、接口上都有注释说明。 部分功能:前台用户信息实体类Entity、实名认证信息实体类Entity、银行卡类型信息实体类Entity、寄售卡类型信息实体类Entity、寄售卡…

【java编程】BCEL ClassLoader

BCEL 介绍 BCEL的全名应该是Apache Commons BCEL,属于Apache Commons项目下的一个子项目。Apache Commons大家应该不陌生,反序列化最著名的利用链就是出自于其另一个子项目——Apache Commons Collections。 BCEL库提供了一系列用于分析、创建、修改Java Class文件的API。就…

借助电脑探究双变量函数问题侧记

记录一次借助电脑探究双变量函数问题的全过程前情概要 偶尔看到下面的习题,想到以前自己整理的双变量函数问题,尝试练手时发现,寻找思路不是很简单的问题,探索一番,对整个过程作以记录,成篇为一侧记 . 典型案例 【2025届高三数学月考3第12题】对于函数 \(f(x)=e^x-x^2+a\…

Paypal最新版本 paypal-server-sdk 使用案例(前端 Vue3 + 后端Spring Boot )

背景 在项目中对接Paypal支付,一开始在网上查了好久,发现资料少,而且陈旧,甚至我都没弄清楚我应该哪个SDK。 我到 maven 中央仓库中,搜索 com.paypal.sdk,能查出不少结果,据我所知,至少有三个sdk可以从后端访问到Paypal:paypal-core:非常陈旧,2016年就停止更新了,但…

【java编程】URLClassLoader

从上面我们研究【java编程】双亲委派模式时进行Debug了源代码, 可以发现的是, URLClassLoader是ExtClassLoader && AppClassLoader的父类(不是父亲), public class Launcher {static class ExtClassLoader extends URLClassLoader {}static class AppClassLoader exten…

秒杀系统

前言 秒杀大家都不陌生。自2011年首次出现以来,无论是双十一购物还是 12306 抢票,秒杀场景已随处可见。简单来说,秒杀就是在同一时刻大量请求争抢购买同一商品并完成交易的过程。从架构视角来看,秒杀系统本质是一个高性能、高一致、高可用的三高系统。而打造并维护一个超大…

.NET周刊【11月第4期 2024-11-24】

国内文章 C# 入门深度学习:万字长文讲解微积分和梯度下降 https://www.cnblogs.com/whuanle/p/18551532 这篇文章主要介绍了使用 C# 进行深度学习的方法,特别是微积分在此领域的应用。作者简要讲解了极限、导数等基本概念,并展示了如何在 C# 中实现这些数学运算,例如将一个…