首页 > 编程语言 >408算法题leetcode--第九天

408算法题leetcode--第九天

时间:2024-09-22 21:20:47浏览次数:3  
标签:第九天 cur nums -- ++ height int leetcode size

344. 反转字符串

class Solution {
public:
    void reverseString(vector<char>& s) {
        int size = s.size();
        for(int i = 0, j = size - 1; i < j; i++, j--){
            swap(s[i], s[j]);
        }
    }
};

11. 盛最多水的容器

class Solution {
public:
    int maxArea(vector<int>& height) {
        // 双指针:S = (j - i) * min(height[i], height[j])
        // 两端双指针:表示全部范围;哪边高度低,哪边往中间移动,即范围减一,同时高度也变化
        int ret = 0;
        int size = height.size();
        for(int i = 0, j = size - 1; i < j;){
            ret = max(ret, (j - i) * min(height[i], height[j]));
            if(height[i] < height[j]){
                i++;
            } else{
                j--;
            }
        }
        return ret;
    }
};

75. 颜色分类

  • 75. 颜色分类
  • 思路:单循环两次,一次放0,一次放1;或者使用双指针,一个用于放0,一个放2
  • 时间:O(n);空间:O(1)
class Solution {
public:
    void sortColors(vector<int>& nums) {
        // 只有0,1,2三个数
        // 第一次遍历将0换到开头,第二次将1换到0后面
        int id = 0, size = nums.size();
        for(int i = 0; i < size; i++){
            if(nums[i] == 0){
                swap(nums[i], nums[id++]);
            }
        }
        for(int i = 0; i < size; i++){
            if(nums[i] == 1){
                swap(nums[i], nums[id++]);
            }
        }
    }
};
  • 第二种做法:
class Solution {
public:
    void sortColors(vector<int>& nums) {
        int zero = 0, two = nums.size() - 1, cur = 0;
        while(cur <= two){  // =: 因为此时two位置的元素还没有遍历
            if(nums[cur] == 0){
                swap(nums[zero++], nums[cur++]);
            } else if(nums[cur] == 1){
                ++cur;
            } else {
                swap(nums[cur], nums[two--]);  // 因为可能2和2交换,所以cur不动
            }
        }
    }
};

标签:第九天,cur,nums,--,++,height,int,leetcode,size
From: https://blog.csdn.net/weixin_58073817/article/details/142366486

相关文章

  • C++入门——类和对象(上)
    文章目录一、类的定义1.1类的定义格式1.2访问限定符1.3类域二、实例化2.1实例化概念2.2对象大小三、this指针四、C++和C语言实现Stack栈的对比总结一、类的定义1.1类的定义格式class为定义类的关键字,Stack为类的名字,{}中为类的主体,注意类定义结束时后⾯分......
  • DDD分层架构
    DDD分层架构、整洁架构、六边形架构都是以领域模型为核心,实行分层架构。内部核心业务逻辑与外部应用、资源隔离并解耦。从而设计出“高内聚、低耦合”的微服务,以实现微服务的架构演进。DDD分层架构使得微服务的架构边界变得清晰。六边形架构提到微服务架构,一定会涉及到六......
  • C++ 解析 RDP 协议
    远程桌面协议(RemoteDesktopProtocol,RDP)是微软开发的一种网络通信协议,用于提供远程桌面会话服务。它允许用户通过网络连接至远程计算机,并像使用本地计算机一样操作远程系统。本文档将详细探讨在C++环境中如何解析RDP协议,涵盖协议层次解析、连接过程管理、数据加密解密、......
  • 力扣72-编辑距离(Java详细题解)
    题目链接:力扣72-编辑距离前情提要:因为本人最近都来刷dp类的题目所以该题就默认用dp方法来做。dp五部曲。1.确定dp数组和i下标的含义。2.确定递推公式。3.dp初始化。4.确定dp的遍历顺序。5.如果没有ac打印dp数组利于debug。每一个dp题目如果都用这五步分析清楚,那么......
  • [机器人仿真]WEBOTS中创建轮腿机器人模型-并联闭环机构的创建和使用
    想着做个轮腿的机器人玩玩,但是如果光用PID做算法,对于轮子加腿的结构似乎效果并不好,为了实现轮腿本身能够飞坡在一定高度下能够跳跃,我想着上个仿真模型来调试和学习LQR算法机器人仿真的软件似乎挺多,我查到比较常用的有ROS套件的一个,还有就是webots本着界面简单,开源(还有校园网方便......
  • 数业智能心大陆:职场倦怠的新解法
    什么是职业倦怠?在职场中,职业倦怠的表现形式丰富多样。从数业智能心大陆AI心理咨询平台的数据来看,职业倦怠呈现出多种状态。教师可能对教学不再满怀热情,精心备课也成为过去式;情绪上容易烦躁、易怒,在工作压力之下,常常因为一些小事就被激怒。比如在项目团队中,成员们意见不合引发争......
  • 2024“华为杯”数模研赛E数据提取代码
    2024年数学建模研究生赛E题从视频中提取数据的代码。主要包括三个部分:车流量计算、各车道车流量计算和平均速度计算。主要讲述了代码的使用方法,包括需要修改的参数和文件路径,以及一些特殊情况的处理方法。同时还提供了参数估计和绘图的相关代码,以及如何根据不同视频视角调整代码......
  • Python 客户端类库之paho-mqtt学习总结
    实践环境Python3.9.13paho-mqtt2.1.0简介EclipsePahoMQTTPython客户端类库实现了MQTT协议版本5.0,3.1.1,和3.1。该类库提供一个客户端类,允许应用连接到MQTT代理并发布消息,订阅主题并检索发布的消息。同时还提供了一个写其它辅助函数,使向MQTT服务器发布一次性消息变......
  • 结对项目
    目录结对项目1.PSP2.1表格2.性能分析3.设计实现过程1.结构1.number2.函数1.solve()2.create()3.getstring()4.pplus(strings)5.check(strings)6.read(strings)7.work(vectorpro)8.write1(vectorans)9.compare(vectorans,vectorans1)10.write2(vectorright,vectorwron......
  • USB2.0 的LPM和USB3.0的LPM区别
    USB2.0和USB3.0都支持低功耗管理机制(LPM,LinkPowerManagement),但两者的实现方式和目标不同。以下是USB2.0的LPM和USB3.0的LPM之间的主要区别:1.协议版本与目的USB2.0LPM(LinkPowerManagement):在USB2.0中,LPM是对原有的挂起/恢复机制的增强。它引入......