【代码随想录】刷题笔记Day51

前言

  • 周六刷题,闻所未闻吧兄弟,不用开组会简直太爽啦

300. 最长递增子序列 - 力扣(LeetCode)

  • 子序列系列问题,用动态规划解决
  • dp[i]含义
    • 表示i之前包括i的以nums[i]结尾的最长递增子序列的长度
  • 递推公式
    • j从0到i-1各个位置的最长升序子序列 + 1 的最大值
    • if (nums[i] > nums[j]) dp[i] = max(dp[i], dp[j] + 1);
  • 初始化
    • dp[i] = 1,长度都为1
  • 遍历顺序
    • 从前到后,i从1到size-1,j从0到i-1
  • 结果
    • 更新dp的时候更新最大值(不是取dp[size-1])
  • class Solution {
    public:int lengthOfLIS(vector<int>& nums) {int len = nums.size();vector<int> dp(len, 1);int res = 1;  // 答案最少也有1for(int i = 1; i < len; i++){for(int j = 0; j < i; j++){if(nums[i] > nums[j]){dp[i] = max(dp[j] + 1, dp[i]);}res = max(res, dp[i]);  // 取长的子序列}}return res;}
    };

674. 最长连续递增序列 - 力扣(LeetCode) 

  • 贪心法

    • 遇到nums[i] > nums[i - 1]的情况,count++,否则count为1,记录count的最大值
    • class Solution {
      public:int findLengthOfLCIS(vector<int>& nums) {int res = 1;  // 连续子序列最少是1int count = 1;for(int i = 1; i < nums.size(); i++){if(nums[i] > nums[i - 1]) count++;  // 连续记录else count = 1;  // 不连续,从头开始res = max(res, count);  // 更新最长连续}return res;}
      };
  •  动规法

    • dp[i]:以下标i为结尾的连续递增的子序列长度为dp[i]
    • if(nums[i] > nums[i - 1])  dp[i] = max(dp[i - 1] + 1, dp[i]);

    • class Solution {
      public:int findLengthOfLCIS(vector<int>& nums) {int len = nums.size();vector<int> dp(len, 1);int res = 1;for(int i = 1; i < len; i++){if(nums[i] > nums[i - 1]){  // 连续记录dp[i] = max(dp[i - 1] + 1, dp[i]);}res = max(dp[i], res);}return res;}
      };

 718. 最长重复子数组 - 力扣(LeetCode)

  • dp[i][j]含义
    • 以下标i - 1为结尾的A,和以下标j - 1为结尾的B,最长重复子数组长度为dp[i][j]
    • 不定义下标i是因为初始化更方便,[-1]直接初始为0
  • 递推公式
    • 当A[i - 1] 和B[j - 1]相等的时候,dp[i][j] = dp[i - 1][j - 1] + 1;
  • 初始化
    • dp[i][0] 和dp[0][j]初始化为0
  • 遍历顺序
    • 两层for遍历两个数组,记录最大值
  • class Solution {
    public:int findLength(vector<int>& nums1, vector<int>& nums2) {vector<vector<int>> dp (nums1.size() + 1, vector<int>(nums2.size() + 1, 0));int result = 0;for (int i = 1; i <= nums1.size(); i++) {for (int j = 1; j <= nums2.size(); j++) {if (nums1[i - 1] == nums2[j - 1]) {dp[i][j] = dp[i - 1][j - 1] + 1;}if (dp[i][j] > result) result = dp[i][j];}}return result;}
    };

后言

  • 好耶,刚好刷完,找女朋友玩耍去咯~ 

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

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

相关文章

揭示量化投资的神秘面纱:深入了解量化交易的核心原理!

随着科技的进步和大数据时代的到来&#xff0c;量化投资已成为金融市场的热门话题。但很多投资者对于量化投资的概念仍感神秘&#xff0c;不清楚其背后的原理和运作机制。本文将深入揭示量化投资的神秘面纱&#xff0c;帮助读者了解量化交易的核心原理。 量化投资的定义与起源 …

Docker 镜像

1、联合文件系统 UnionFS&#xff08;联合文件系统)&#xff1a;Union文件系统〈UnionFS)是一种分层、轻量级并且高性能的文件系统&#xff0c;它支持对文件系统的修改作为一次提交来一层层的叠加&#xff0c;同时可以将不同目录挂载到同一个虚拟文件系统下(unite several dir…

CCF认证+蓝桥杯习题训练

贪心 *上取整公式* *代码展示* #include <iostream> #include <cstring> #include <algorithm>using namespace std;const int N 1e5 10;typedef long long LL;int v[N] , a[N];int main() {int n , d;cin >> n >> d;for(int i 1 ; i < n…

函数式编程 - 组合compose的使用方法

函数式编程中有一个比较重要的概念就是函数组合&#xff08;compose&#xff09;,组合多个函数&#xff0c;同时返回一个新的函数。调用时&#xff0c;组合函数按顺序从右向左执行。右边函数调用后&#xff0c;返回的结果&#xff0c;作为左边函数的参数传入&#xff0c;严格保…

Linux环境下使用flv.js + websokect播放RTSP视频流

本文适用于Linux系统部署Web项目&#xff0c;通过浏览器播放RTSP视频流 背景 ​ 在最近的项目中&#xff0c;涉及到海康威视接入的视频监控播放问题&#xff0c;海康这边可以获取到的视频流是rtsp格式&#xff0c;web端目前没有直接可以播放的组件&#xff0c;于是查阅众多博…

工业级安卓PDA超高频读写器手持掌上电脑,RFID电子标签读写器

掌上电脑&#xff0c;又称为PDA。工业级PDA的特点就是坚固&#xff0c;耐用&#xff0c;可以用在很多环境比较恶劣的地方。 随着技术的不断发展&#xff0c;加快了数字化发展趋势&#xff0c;RFID技术就是RFID射频识别及技术&#xff0c;作为一种新兴的非接触式的自动识别技术&…

python处理目录下文本文件去除空格和空行

一&#xff1a;实现思路&#xff1a; 要想实现去除某个目录下所有txt文件的空格&#xff0c;需要循环遍历一个目录下的所有文件&#xff0c; 获取文件的每行数据去除空格以后&#xff0c;重新保存数据到当前当前文件中。 处理空格,我们使用正则&#xff0c;这样可以去除字符串…

Java并查集设计以及路径压缩实现

Java全能学习面试指南&#xff1a;https://javaxiaobear.cn 并查集是一种树型的数据结构 &#xff0c;并查集可以高效地进行如下操作&#xff1a; 查询元素p和元素q是否属于同一组合并元素p和元素q所在的组 1、并查集的结构 并查集也是一种树型结构&#xff0c;但这棵树跟我们之…

C++面试八股--inline函数

1.inline 内联函数 1.1 特征 相当于把内联函数里面的内容写在调用内联函数处&#xff1b;相当于不用执行进入函数的步骤&#xff0c;直接执行函数体&#xff1b;相当于宏&#xff0c;却比宏多了类型检查&#xff0c;真正具有函数特性&#xff1b;编译器一般不内联包含循环、递归…

uniapp 如何使用echarts 以及解决tooltip自定义不生效问题

使用的是echarts-for-wx插件&#xff1b; 正常写法案例&#xff1a;给tooltip数值加个% <template><view><uni-ec-canvas class"uni-ec-canvas"id"uni-ec-canvas"ref"canvas"canvas-id"uni-ec-canvas":ec"ec&quo…

【数据库】sql优化有哪些?从query层面和数据库层面分析

目录 归纳sql本身的优化数据库层面的优化 归纳 这类型问题可以称为&#xff1a;Query Optimization&#xff0c;从清华AI4DB的paper list中&#xff0c;该类问题大致可以分为&#xff1a; Query RewriterCardinality EstimationCost EstimationPlan Optimization 从中文的角…

JSP使用websocket

jsp增加websocket $(function(){registerWebsocket(); });var ws; function registerWebsocket() {// 注册路径 加上自己的用户名ws new WebSocket("ws://127.0.0.1:8081/client/notify/test")//连接成功建立的回调方法ws.onopen function () {ws.send("客户…

SkipList 的索引过程,能否越两级搜索

“SkipList 的索引过程&#xff0c;能否越两级搜索&#xff1f;” 昨天&#xff0c;一个工作 7 年的粉丝&#xff0c;去某外包公司面试&#xff0c;被问到这个问题不知道该怎么回答。 今天正好有空&#xff0c;给大家分享一下这个问题的回答思路。 对了&#xff0c;这个问题…

ZooKeeper 实战(四) Curator Watch事件监听

文章目录 ZooKeeper 实战(四) Curator Watch事件监听0.前言1.Watch 事件监听概念2.NodeCache2.1.全参构造器参数2.2.代码DEMO2.3.日志输出 3.PathChildrenCache3.1.全参构造器参数3.2.子节点监听时间类型3.2.代码DEMO 4.TreeCache4.1.构造器参数4.2.代码DEMO4.3.日志输出 ZooKe…

Flink(十二)【容错机制】

前言 最近已经放假了&#xff0c;但是一直在忙一个很重要的自己的一个项目&#xff0c;用 JavaFX 和一个大数据组件联合开发一个功能&#xff0c;也算不枉我学了一次 JavaFX&#xff0c;收获很大&#xff0c;JavaFX 它作为一个 GUI 开发语言&#xff0c;本质还是 Java&#xff…

MSF流量加密

1、背景介绍 在MSF中生成shell&#xff0c;并上线运行时。都是通过http https tcp等协议传输。虽然MSF本身会对流量进行加密&#xff0c;但MSF太出名以致于其加密特征容易被IPS&#xff0c;WAF等可以检测带有攻击的特征的设备拦截或记录。 2、生成 SSL 证书 openssl req -x50…

Python操作PPT:轻松创建、编辑和展示幻灯片

引言&#xff1a; 在现代办公环境中&#xff0c;演示文稿已经成为一种常见的沟通工具。然而&#xff0c;使用传统的PowerPoint软件创建和编辑幻灯片可能会耗费大量的时间和精力。幸运的是&#xff0c;Python作为一种功能强大的编程语言&#xff0c;提供了许多库和工具&#xff…

关于运维·关于数据库面试题

目录 一、数据库类型 二、数据库引擎 三、mysql数据库类型 四、mysql的约束添加 五、主从复制原理 六、主从方式有几种 七、mysql主从数据不一致的原因 八、mysql的优化 九、什么是事务的特征 十、数据库读写分离的好处 十一、怎样优化sql语句 十二、mysql的同步方…

二Dockerfile实战

Dockerfile实战 实战1&#xff1a;使用Dockerfile修改Nginx首页 创建一个Dockerfile&#xff0c;内容如下&#xff1a; FROM nginx RUN echo <h1>Spring Cloud与Docker微服务实战</h1> > /usr/share/nginx/html/index.html实战2&#xff1a;使用Dockerfile在…

谷粒商城-商品服务-品牌管理-阿里云云存储+JSR303数字校验+统一异常处理

阿里云云存储OSS 分布式系统上传文件 分布式系统上传文件 单体应用上传&#xff1a;上传文件到服务器&#xff0c;想获取文件时再向服务器发请求获取文件。 分布式系统上传&#xff1a; 因为有多台服务器&#xff0c;为防止负载均衡导致获取文件时没找到对应的服务器&#xf…