力扣天天练--week3-LeetCode75

topic75-9-t443:压缩字符串

题目描述:

给你一个字符数组 chars ,请使用下述算法压缩:

从一个空字符串 s 开始。对于 chars 中的每组 连续重复字符 :

如果这一组长度为 1 ,则将字符追加到 s 中。
否则,需要向 s 追加字符,后跟这一组的长度。
压缩后得到的字符串 s 不应该直接返回 ,需要转储到字符数组 chars 中。需要注意的是,如果组长度为 10 或 10 以上,则在 chars 数组中会被拆分为多个字符。

请在 修改完输入数组后 ,返回该数组的新长度。

你必须设计并实现一个只使用常量额外空间的算法来解决此问题。

示例:

 思路:

  1. 定义一个辅助函数 reverse,用于反转字符列表中指定位置之间的字符。
  2. 定义变量 n,表示字符列表的长度。
  3. 定义变量 write 和 left,表示压缩后的字符列表和当前字符的左边界。
  4. 遍历字符列表,用 read 指针指向当前字符。
  5. 如果 read 指针指向字符列表的最后一个元素,或者当前字符与下一个字符不同,执行以下操作:
    • 将当前字符写入压缩后的字符列表。
    • 计算相同字符的数量,即 read - left + 1
    • 如果相同字符的数量大于 1,则将该数字转换为字符串,并写入压缩后的字符列表中。
    • 调用 reverse 函数,将数字字符串反转,使其顺序正确。
    • 将 left 指针移动到下一个字符的位置。
    • 将 write 指针移动到下一个位置,以准备写入下一个字符或数字。
  6. 返回 write,表示压缩后的字符列表的长度。

 

class Solution:
    def compress(self, chars: List[str]) -> int:
        # 定义一个辅助函数 reverse,用于反转字符列表中指定位置之间的字符
        def reverse(left: int, right: int) -> None:
            while left < right:
                chars[left], chars[right] = chars[right], chars[left]
                left += 1
                right -= 1

        n = len(chars)
        write = left = 0 # write 表示压缩后的字符列表中当前位置,left 表示当前字符的左边界
        for read in range(n): # 遍历字符列表,用 read 指针指向当前字符
            if read == n - 1 or chars[read] != chars[read + 1]: # 如果当前字符是最后一个字符或者与下一个字符不同
                chars[write] = chars[read] # 将当前字符写入压缩后的字符列表
                write += 1 # 将 write 指针向右移动一位
                num = read - left + 1 # 计算相同字符的数量
                if num > 1: # 如果相同字符的数量大于 1
                    anchor = write # 将 anchor 指针指向 write 指针当前位置,用于记录数字字符串的起始位置
                    while num > 0: # 将数字转换为字符串,并写入压缩后的字符列表中
                        chars[write] = str(num % 10)
                        write += 1
                        num //= 10
                    reverse(anchor, write - 1) # 将数字字符串反转,使其顺序正确
                left = read + 1 # 将 left 指针移动到下一个字符的位置,用于记录下一段相同的字符的左边界
        return write # 返回 write,表示压缩后的字符列表的长度

topic75-10-t283:移动零

题目描述:

给定一个数组 nums,编写一个函数将所有 0 移动到数组的末尾,同时保持非零元素的相对顺序。

请注意 ,必须在不复制数组的情况下原地对数组进行操作。

示例:

 思路:

  1. 定义变量 i 和 j,分别表示当前遍历到的元素和当前非零元素的位置。
  2. 遍历列表 nums,使用指针 i 指向当前遍历到的元素。
  3. 如果 i 指向的元素不为 0,将其移到列表的非零元素区域,并将指针 j 向右移动一位,以便下一次将非零元素移到该位置。
  4. 遍历结束后,将列表中剩余的元素全部赋值为 0,以将它们移到列表的末尾。
class Solution:
    def moveZeroes(self, nums: List[int]) -> None:
        """
        Do not return anything, modify nums in-place instead.
        """
        i = 0 # 定义指针 i,表示当前遍历到的元素
        j = 0 # 定义指针 j,表示当前非零元素的位置
        
        # 遍历列表 nums
        while i < len(nums):
            # 如果当前元素不为 0,将其移到列表的非零元素区域
            if nums[i] != 0:
                nums[j] = nums[i]
                j += 1 # 将指针 j 向右移动一位,以便下一次将非零元素移到该位置
            i += 1 # 将指针 i 向右移动一位,遍历下一个元素
        
        # 将列表中剩余的元素全部赋值为 0,以将它们移到列表的末尾
        while j < len(nums):
            nums[j] = 0
            j += 1
        
        # 算法结束,返回 None

topic75-11-t392:判断子序列

题目描述:

给定字符串 s 和 t ,判断 s 是否为 t 的子序列。

字符串的一个子序列是原始字符串删除一些(也可以不删除)字符而不改变剩余字符相对位置形成的新字符串。(例如,"ace"是"abcde"的一个子序列,而"aec"不是)。

示例:

 思路:

  1. 定义两个指针 first 和 second,分别指向 t 和 s 的开头。
  2. 计算字符串 t 和 s 的长度 lengtht 和 lengths,如果 s 的长度为 0,则直接返回 True。
  3. 使用 while 循环遍历字符串 t,直到 first 指针到达 t 的末尾。
  4. 如果 s[second] 和 t[first] 相等,则将 first 和 second 指针分别向右移动一位,继续进行比较。
  5. 如果 s[second] 和 t[first] 不相等,则将 first 指针向右移动一位,继续进行比较。
  6. 如果 second 指针到达了 s 的末尾,说明 s 是 t 的子序列,返回 True。
  7. 如果 first 指针到达了 t 的末尾,说明已经遍历完了整个字符串 t,但是没有找到 s,返回 False。

 

class Solution:
    def isSubsequence(self, s: str, t: str) -> bool:
        first, second = 0, 0 # 初始化双指针
        lengtht, lengths = len(t), len(s)
        if lengths == 0: # 如果 s 的长度为 0,则直接返回 True
            return True
        while first < lengtht: # 使用 while 循环遍历字符串 t
            if s[second] == t[first]: # 如果 s[second] 和 t[first] 相等,则将指针分别向右移动一位,继续进行比较
                first += 1
                second += 1
            elif s[second] != t[first]: # 如果 s[second] 和 t[first] 不相等,则将 first 指针向右移动一位,继续进行比较
                first += 1
            if second == lengths: # 如果 second 指针到达 s 的末尾,说明 s 是 t 的子序列,返回 True
                return True
        return False # 如果 first 指针到达 t 的末尾,说明已经遍历完了整个字符串 t,但是没有找到 s,返回 False

topic75-13-t1679:K和数对的最大数目

题目描述:

给你一个整数数组 nums 和一个整数 k 。

每一步操作中,你需要从数组中选出和为 k 的两个整数,并将它们移出数组。

返回你可以对数组执行的最大操作数。

示例:

 思路1:先对数组排序,然后左右指针逼近,统计其中符合条件的个数,最后返回count。时间复杂度O(nlogn)

class Solution:
    def maxOperations(self, nums: List[int], k: int) -> int:
        # 思路:先排序,再左右指针逼近
        count = 0 # 用来存储结果
        length = len(nums)
        nums.sort() # 对 nums 排序
        left, right = 0, length - 1 # 定义左右指针,分别指向 nums 的开头和结尾
        while left < right: # 使用 while 循环遍历 nums
            if nums[left] + nums[right] == k: # 如果 nums[left] + nums[right] == k,说明找到了一对元素的和等于 k
                count += 1 # 将 count 值加 1
                left += 1 # 将 left 指针向右移动一位
                right -= 1 # 将 right 指针向左移动一位
            elif nums[left] + nums[right] > k: # 如果 nums[left] + nums[right] > k,说明当前两个元素的和太大,将 right 指针向左移动一位
                right -= 1
            else: # 如果 nums[left] + nums[right] < k,说明当前两个元素的和太小,将 left 指针向右移动一位
                left += 1
        return count # 返回 count 的值

思路2:时间复杂度O(n)

  1. 使用 Python 的 Counter 类对列表 nums 进行统计,得到一个字典 tmp,其中键为列表中的元素,值为该元素在列表中出现的次数。
  2. 初始化变量 ans,用于存储结果,将其初始化为 0。
  3. 遍历字典 tmp,对于每个键值对 (num, count),根据其值的大小和键的值与 k 的关系,计算符合条件的数对数量,并将其加入 ans 中。
  4. 算法结束,返回结果。

 

from collections import Counter

class Solution:
    def maxOperations(self, nums: List[int], k: int) -> int:
        tmp = Counter(nums) # 使用 Counter 统计 nums 中每个元素出现的次数
        ans = 0 # 初始化变量 ans,用于存储结果
        for num in tmp: # 遍历 Counter 对象 tmp
            if num * 2 < k: # 如果 num * 2 < k,则说明可以找到与 num 相加等于 k 的数
                ans += min(tmp[num], tmp.get(k-num, 0)) # 将 num 和 k - num 中较小值的出现次数加入 ans 中
            elif num * 2 == k: # 如果 num * 2 == k,则说明 num 和 k - num 相等
                ans += tmp[num] // 2 # 将 num 的出现次数的一半加入 ans 中
            else: # 如果 num * 2 > k,则说明再往后的数都比 k - num 大,不可能找到符合条件的数对
                break
        return ans # 返回结果 ans

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

如若内容造成侵权/违法违规/事实不符,请联系我们进行投诉反馈qq邮箱809451989@qq.com,一经查实,立即删除!

相关文章

【图像处理】使用自动编码器进行图像降噪(改进版)

阿里雷扎凯沙瓦尔兹 一、说明 自动编码器是一种学习压缩和重建输入数据的神经网络。它由一个将数据压缩为低维表示的编码器和一个从压缩表示中重建原始数据的解码器组成。该模型使用无监督学习进行训练&#xff0c;旨在最小化输入和重建输出之间的差异。自动编码器可用于降维、…

Linux之Shell 编程详解(一)

第 1 章 Shell 概述 1&#xff09;Linux 提供的 Shell 解析器有 [atguiguhadoop101 ~]$ cat /etc/shells /bin/sh /bin/bash /usr/bin/sh /usr/bin/bash /bin/tcsh /bin/csh2&#xff09;bash 和 sh 的关系 [atguiguhadoop101 bin]$ ll | grep bash -rwxr-xr-x. 1 root root …

Ubuntu-解决包依赖关系

Ubuntu-解决包依赖关系的办法 安装软件包的时候&#xff0c;有时会遇到类似下图的依赖问题&#xff0c;无法正常安装&#xff0c;下面提供三种方法解决依赖问题。 1.可以尝试用下面方法处理依赖问题&#xff0c;紧跟前一条安装命令后面输入下面命令&#xff0c;然后再执行安装…

【学习笔记】行为识别SOTA方法比较

这里写目录标题 前言方法1 基于CNN的方法Slow-fast&#xff1a; 2 基于Vision-Transformer的方法Video TimeSformer :Video Swin Transformer : 3、基于自监督的方法VideoMAE&#xff1a; 4、基于多模态的方法Intern video: 前言 常用行为识别数据集包括&#xff1a;HMDB-51、…

windows使用多账户Git,多远程仓库版本管理

1 清除全局配置 git config --global --list // 看一下是否配置过user.name 和 user.email git config --global --unset user.name // 清除全局用户名 git config --global --unset user.email // 清除全局邮箱 2 本地仓库&#xff0c;每个远程对应的本地仓库目录下执行 $…

AddForce

ForceMode&#xff1a; Force&#xff1a;关注的是力整体 Impulse&#xff1a;关注的是冲量&#xff0c;与质量相关 VelocityChange&#xff1a;关注的是速度&#xff0c;与质量无关 Acceleration&#xff1a;关注的是加速度&#xff0c;与质量无关 public void AddForce…

基于FasterRCNN深度学习网络的车辆检测算法matlab仿真

目录 1.算法运行效果图预览 2.算法运行软件版本 3.部分核心程序 4.算法理论概述 5.算法完整程序工程 1.算法运行效果图预览 2.算法运行软件版本 MATLAB2022A 3.部分核心程序 ....................................................................... % 训练Faster R-…

hw技战法整理参考

目录 IP溯源反制 账户安全策略及预警 蜜罐部署联动方案

数据结构【查找】

第八章 查找 提前了解&#xff1a; 1、关键字&#xff1a; 若关键字能唯一标识一个数据元素&#xff0c;则关键字称为主关键字&#xff1b;若能标识若干个数据元素的关键字称为次关键字&#xff1b; 2、查找&#xff08;检索&#xff09;&#xff1a;顾名思义&#xff0c;给定…

GitHub上怎么寻找项目?

前言 下面由我精心整理的关于github项目资源搜索的一些方法&#xff0c;这些方法可以帮助你更快更精确的搜寻到你需要的符合你要求的项目。 写文章不易&#xff0c;如果这一篇问文章对你有帮助&#xff0c;求点赞求收藏~ 好&#xff0c;下面我们直接进入正题——> 首先我…

尚医通06:数据字典+EasyExcel+mongodb

内容介绍 1、数据字典列表前端 2、EasyExcel介绍、实例 3、数据字典导出接口、前端 4、数据字典导入接口、前端 5、数据字典添加redis缓存 6、MongoDB简介 7、MongoDB安装 8、MongoDB基本概念 数据字典列表前端 1、测试问题 &#xff08;1&#xff09;报错日志 &am…

升讯威在线客服系统是如何实现对 IE8 完全完美支持的(怎样从 WebSocket 降级到 Http)【干货】

简介 升讯威在线客服与营销系统是基于 .net core / WPF 开发的一款在线客服软件&#xff0c;宗旨是&#xff1a; 开放、开源、共享。努力打造 .net 社区的一款优秀开源产品。 完整私有化包下载地址 &#x1f4be; https://kf.shengxunwei.com/freesite.zip 当前版本信息 发布…

QTDAY3

闹钟 头文件 #ifndef WIDGET_H #define WIDGET_H#include <QWidget> #include <QTimerEvent> //定时器事件处理函数 #include <QTime> //时间类 #include <QString> #include <QPushButton> #include <QTextToSpeech> #include …

【嵌入式学习笔记】嵌入式基础9——STM32启动过程

1.MAP文件浅析 1.1.MDK编译后生成的中间过程文件 1.2.Map文件构成&#xff1a; 程序段交叉引用关系&#xff08;Section Cross References&#xff09;&#xff1a;描述各文件之间函数调用关系删除映像未使用的程序段&#xff08;Removing Unused input sections from the im…

【驱动开发day4作业】

头文件代码 #ifndef __HEAD_H__ #define __HEAD_H__ typedef struct{unsigned int MODER;unsigned int OTYPER;unsigned int OSPEEDR;unsigned int PUPDR;unsigned int IDR;unsigned int ODR; }gpio_t; #define PHY_LED1_ADDR 0X50006000 #define PHY_LED2_ADDR 0X50007000 #…

使用Wps减小PDF文件的大小

第一步、打开左上角的文件 第二步、点击打印选项 第三步、点击打印按钮

[数据库]对数据库事务进行总结

文章目录 1、什么是事务2、事务的特性&#xff08;ACID&#xff09;3、并发事务带来的问题4、四个隔离级别&#xff1a; 1、什么是事务 事务是逻辑上的一组操作&#xff0c;要么都执行&#xff0c;要么都不执行。 事务最经典也经常被拿出来说例子就是转账了。假如小明要给小红…

基于Fringe-Projection环形投影技术的人脸三维形状提取算法matlab仿真

目录 1.算法运行效果图预览 2.算法运行软件版本 3.部分核心程序 4.算法理论概述 5.算法完整程序工程 1.算法运行效果图预览 2.算法运行软件版本 matlab2022a 3.部分核心程序 .................................................................... figure; imshow(Im…

用windeployqt.exe打包Qt代码

首先找到我们编译Qt代码的对应Qt版本的dll目录&#xff0c;该目录下有windeployqt.exe&#xff1a; D:\DevTools\Qt\5.9\msvc2017_64\bin 在这个目录下打开cmd程序。 然后把要打包的exe放到一个单独的目录下&#xff0c;比如&#xff1a; 然后在cmd中调用&#xff1a; winde…

Qt : day4

1.思维导图 2.服务器 #include "widget.h" #include "ui_widget.h"Widget::Widget(QWidget *parent): QWidget(parent), ui(new Ui::Widget) {ui->setupUi(this);//给服务器指针实例化空间server new QTcpServer(this);}Widget::~Widget() {delete ui;…