刷题日记:面试经典 150 题 DAY6

news2024/11/30 8:58:36

刷题日记:面试经典 150 题 DAY6

  • 392. 判断子序列
  • 167. 两数之和 II - 输入有序数组
  • 11. 盛最多水的容器
  • 15. 三数之和
  • 209. 长度最小的子数组

392. 判断子序列

原题链接 392. 判断子序列

双指针,i指向s,j指向t

  • 如果s[i]==t[j],则匹配到一个字母,两个指针都后移
  • 如果s[i]!=t[j],则指针j后移继续寻找
class Solution {
public:
    bool isSubsequence(string s, string t) {
        int i = 0, j = 0;
        if(s.size() == 0) return true;
        while(i < s.size() && j < t.size()) {
            if(s[i] != t[j]) {
                j++;
                if(j >= t.size()) {
                    return false;
                }
            } else {
                i++, j++;
                if(i >= s.size()) {
                    return true;
                }
            }
        }
        return false;
    }
};

167. 两数之和 II - 输入有序数组

原题链接 167. 两数之和 II - 输入有序数组
双指针本质上是对搜索空间进行某种顺序的遍历,一般都会用得上某种单调性
对于题来说,搜索空间如下所示
在这里插入图片描述

  • 选择棕色作为起点,是因为从这里出发可以仅通过(向左,向右)两个动作到达任意一个状态,。这保证了不会有答案被漏,
  • 比起爆搜来说可以提升性能的原因在于,利用单调性进行搜索的剪枝。比如我们得知当前状态比目标状态大时,就可以确定一系列状态都不可能是目标状态了。在这里插入图片描述
    从实现上来说,就是一个指针位于数列头部,一个位于尾部,两个指针逐渐向中间靠拢
class Solution {
public:
    vector<int> twoSum(vector<int>& numbers, int target) {
        for(int i = 0, j = numbers.size()-1;i < j;) {
            if(numbers[i]+numbers[j] == target) {
                return {i+1 , j+1};
            }
            if(numbers[i]+numbers[j] < target) {
                i++;
            }
            if(numbers[i]+numbers[j] > target) {
                j--;
            }
        }
        return {};
    }
};

11. 盛最多水的容器

原题链接 11. 盛最多水的容器

容积等于 两个板子相差的距离×较矮板子的的高。使用双指针,从最宽的底开始,接下里考虑移动哪个指针

  • 若移动指向较高板子的指针,则底一定变小,高也一定变小(因为高总是较低板子的高)
  • 所以只能移动指向较低板子的指针
class Solution {
public:
    int maxArea(vector<int>& height) {
        int result = 0;
        for(int i = 0, j = height.size()-1;i < j;) {
            result = max(result,(j-i)*min(height[i],height[j]));
            if(height[i] < height[j]) {
                i++;
            } else {
                j--;
            }
        }
        return result;
    }
};

15. 三数之和

爆搜 O ( N 3 ) O(N^3) O(N3),可以比较简单的想到先排序,再固定一个数就可以使用双指针了。
我一开始脑抽,想着固定中间大小的那个(老是想追求对称性导致的),直接处理重复情况处理闷了。
固定最小的数比较好做。把最小数固定其实就回到了167. 两数之和 II - 输入有序数组。注意两点

  • 最外层循环遍历到正数就可以立马停止
  • 每次移动指针时,都尽可能到达连续相同元素的尾部,防止重复的情况发生
class Solution {
public:
    vector<vector<int>> threeSum(vector<int>& nums) {
	    int len = nums.size();
	    sort(nums.begin(), nums.end());
	    vector<vector<int>> result;
	    for(int i = 0;i < len-2;i++) {
            if(nums[i] > 0) break;
            if(i > 0 && nums[i-1] == nums[i]) continue;
            for(int j = i+1, k = len-1;j < k;) {
                int sum = nums[i]+nums[j]+nums[k];
                if(sum < 0) {
                    for(j += 1;j<k && nums[j-1]==nums[j];j++);
                } else if(sum>0) {
                    for(k -= 1;j<k && nums[k+1]==nums[k];k--);
                } else {
                    result.push_back({nums[i],nums[j],nums[k]});
                    for(j += 1;j<k && nums[j-1]==nums[j];j++);
                    for(k -= 1;j<k && nums[k+1]==nums[k];k--);
                }
            }
        }
	    return result;
    }
};

209. 长度最小的子数组

原题链接 209. 长度最小的子数组

想象数组是一组竖杆,杆与杆之间距离不一。有个皮筋,现在是松弛状态,想要找到能让它绷紧时跨越最少的竖杆。
先给皮筋套在最左边,然后抻右端,直到皮筋紧,然后一点点松左端,直到恰好送掉,然后在抻右端,重复这个步骤

class Solution {
public:
    int minSubArrayLen(int target, vector<int>& nums) {
        int len = nums.size();
        int ans = len+1;
        int left = 0, right = 0;
        int length = 0;
        int sum = 0;
        while(right < len) {
            sum += nums[right];
            length++;
            while(sum >= target) {
                ans = min(ans,length);
                sum -= nums[left];
                length--;
                left++;
            }
            right++;
        }
        if(ans > len) return 0;
        return ans;
    }
};

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

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

相关文章

ARM开发板实现24位BMP图片缩放

ARM开发板实现24位BMP图片缩放 一、linux平台bmp图片缩放 最近想在ARM开发板实现BMP图片的缩放&#xff0c;查看了一些资料&#xff0c;大家部分理论知识可参考&#xff1a; akynazh博主 &#xff0c;这位博主程序以window平台为主进行显示&#xff0c;发现在linux平台下编译…

【Leetcode】1793. 好子数组的最大分数

文章目录 题目思路代码复杂度分析时间复杂度空间复杂度 结果总结 题目 题目链接&#x1f517; 给你一个整数数组 n u m s nums nums &#xff08;下标从 0 0 0 开始&#xff09;和一个整数 k k k 。 一个子数组 ( i , j ) (i, j) (i,j) 的 分数 定义为 m i n ( n u m s …

Livox激光雷达 mid360 跑 fastlio2 - 流程记录

mid360 跑 fastlio2 一、配置 mid360 环境1.1、主机配置静态IP为192.168.1.501.2、Livox-SDK21.3、Livox_ros_driver2二、Fast-lio22.1、下载源码2.2、修改代码2.3、编译、运行 提示一下&#xff0c;如果在一些板上&#xff08;比如rk3399&#xff0c;或者是树莓派 &#xff0…

蓝桥杯java组 螺旋折线

题目描述 如图所示的螺旋折线经过平面上所有整点恰好一次。 对于整点(X, Y)&#xff0c;我们定义它到原点的距离dis(X, Y)是从原点到(X, Y)的螺旋折线段的长度。 例如dis(0, 1)3, dis(-2, -1)9 给出整点坐标(X, Y)&#xff0c;你能计算出dis(X, Y)吗&#xff1f; 【输入格…

Spring-AOP面相切面编程示例(有详细注释)

前提知识Spring-IOC容器注解方式使用https://blog.csdn.net/m0_61160520/article/details/136784799?spm1001.2014.3001.5501切点表达式https://blog.csdn.net/m0_61160520/article/details/136782885?spm1001.2014.3001.5501 案例 1.创建项目 2.导入依赖 <dependencie…

CSS 三大特性 详细讲解

CSS 三大特性及代码解释 层叠性 当相同选择器设置相同样式且发生冲突时&#xff0c;此时后者的样式会覆盖&#xff08;层叠&#xff09;前者冲突样式。CSS的层叠性就是用于解决样式冲突问题。 Input&#xff1a; <style>div {color: red;}div { color: blue; <!-…

webconfig-boot分布式项目Web一站式配置

1、前言 最近利用空余时间写了一个项目webconfig-boot 。该项目主要配置了web项目常用的一些配置&#xff0c;如统一参数校验、统一异常捕获、统一日期的处理、常用过滤器、常用注解等。引入依赖接口完成常规的web配置。 这里也是总结了笔者在项目开发中遇到的一些常用的配置…

springboot项目讲解

技术栈 vue(前端) springboot(后端主框架) mybatis&#xff08;ORM&#xff0c;用于后端和数据库的映射&#xff0c;即java对象转换成表&#xff09; mysql (关系型数据库) 顶层结构 .idea&#xff1a; idea缓存文件(不需要管) src&#xff1a;代码核心文件夹 —main&#xf…

Windows Terminal配置 美化

Windows 终端自定义提示符设置 | Microsoft Learn 安装PowerShell7 在 Windows 上安装 PowerShell - PowerShell | Microsoft Learn 设置默认为 PowerShell7 安装 在powerShell 开启远程权限 Set-ExecutionPolicy RemoteSigned -scope CurrentUserscoop 执行 iwr -useb ht…

王道机试C++续第6章 数学问题 贪心算法和蓝桥杯真题Day37倒计时24天

6.4 分解质因数 上一节讨论了素数的问题&#xff0c;而素数常用于分解质因数。每个数都可以写成一个或几个质数相乘的形式&#xff0c;其中每个质数都是这个数的质因数。把一个数用质因数相乘的形式表示出来&#xff0c;就称为分解质因数。例如&#xff0c;对一个数 x 分解素…

Centos7没有可用软件包 ifconfig问题解决

问题描述 在Centos7中查看ip没有ifconfig&#xff0c;使用yum安装ifconfig报错没有可用软件包 ifconfig问题解决 [rootlocalhost etc]# yum -y install ifconfig 已加载插件&#xff1a;fastestmirror base …

进程间通信 之 共享内存

目录 什么是共享内存&#xff1f; 共享内存的系统调用接口 共享内存 进程间通信的本质及前提&#xff1a;让不同的进程看到同一份资源&#xff01; 共享内存区是最快的IPC形式。一旦这样的内存映射到共享它的进程的地址空间&#xff0c;这些进程间数据传递不再涉及到内核&a…

鸿蒙开发实战:【网络管理-Socket连接】

介绍 本示例主要演示了Socket在网络通信方面的应用&#xff0c;展示了Socket在两端设备的连接验证、聊天通信方面的应用。 效果预览 使用说明 1.打开应用&#xff0c;点击用户文本框选择要登录的用户&#xff0c;并输入另一个设备的IP地址&#xff0c;点击确定按钮进入已登录…

【毛毛讲书】【好运】为什么有些人天生就有好运眷顾?

重磅专栏推荐&#xff1a; 《大模型AIGC》 《课程大纲》 《知识星球》 本专栏致力于探索和讨论当今最前沿的技术趋势和应用领域&#xff0c;包括但不限于ChatGPT和Stable Diffusion等。我们将深入研究大型模型的开发和应用&#xff0c;以及与之相关的人工智能生成内容&#xff…

什么是web组态?Web组态软件哪个好用?

随着工业4.0的到来&#xff0c;物联网、大数据、人工智能等技术的融合应用&#xff0c;使得工业领域正在经历一场深刻的变革。在这个过程中&#xff0c;Web组态技术以其独特的优势&#xff0c;正在逐渐受到越来越多企业的关注和认可。那么&#xff0c;什么是Web组态&#xff1f…

轻巧的elasticsearch可视化工具

一、概述 常见的ES可视化工具有&#xff1a; kibanaelasticsearch-headElasticHDDejavucerebroelasticview 一、安装elasticview 在众多ES可视化龚居中&#xff0c;elasticview是一款比较轻量简洁&#xff0c;兼容性较好&#xff0c;可以兼容多个ES版本&#xff0c;不但可以进…

[蓝桥杯 2020 省 AB3] 限高杆

分层图建图典题 #include<bits/stdc.h> using namespace std; using ll long long; #define int long long const int N 6e510; const int inf 0x3f3f3f3f; const int mod 1e97; int e[N],ne[N],w[N],h[N],idx; void add(int a,int b,int c){e[idx] b,ne[idx] h[a]…

外键约束

目录 外键约束 对数据表进行初期设计&#xff0c;暂时不使用外键 验证限制三 验证级联删除 设置级联更新 Oracle从入门到总裁:​​​​​​https://blog.csdn.net/weixin_67859959/article/details/135209645 外键约束 外键约束主要是在父子表关系中体现的一种约束操作。…

【二叉树】算法例题

目录 九、二叉树 68. 二叉树的最大深度 ① 69. 相同的树 ① √ 70. 翻转二叉树 ① 71. 对称二叉树 ① 72. 从前序与中序遍历序列构造二叉树 ② 73. 从中序与后续遍历序列构造二叉树 ② 74. 填充每个节点的下一个右侧节点指针 II ② 75. 二叉树展开为链表 ② 76.…

鸿蒙实战开发:【FaultLoggerd组件】讲解

简介 Faultloggerd部件是OpenHarmony中C/C运行时崩溃临时日志的生成及管理模块。面向基于 Rust 开发的部件&#xff0c;Faultloggerd 提供了Rust Panic故障日志生成能力。系统开发者可以在预设的路径下找到故障日志&#xff0c;定位相关问题。 架构 Native InnerKits 接口 Si…