LeetCode刷题---简单组(四)

news2025/1/12 21:09:53

文章目录

  • 🍒题目一 27. 移除元素
  • 🍒解法一
  • 🍒题目二 28. 找出字符串中第一个匹配项的下标
  • 🍒解法一
  • 🍒题目三 35. 搜索插入位置
  • 🍒解法一

🍒题目一 27. 移除元素

请添加图片描述
给你一个数组 nums 和一个值 val,你需要 原地 移除所有数值等于 val 的元素,并返回移除后数组的新长度。

不要使用额外的数组空间,你必须仅使用 O(1) 额外空间并 原地 修改输入数组。

元素的顺序可以改变。你不需要考虑数组中超出新长度后面的元素。

说明:

为什么返回数值是整数,但输出的答案是数组呢?

请注意,输入数组是以「引用」方式传递的,这意味着在函数里修改输入数组对于调用者是可见的。

你可以想象内部操作如下:

// nums 是以“引用”方式传递的。也就是说,不对实参作任何拷贝
int len = removeElement(nums, val);

// 在函数里修改输入数组对于调用者是可见的。
// 根据你的函数返回的长度, 它会打印出数组中 该长度范围内 的所有元素。
for (int i = 0; i < len; i++) {
print(nums[i]);
}

示例 1:

输入:nums = [3,2,2,3], val = 3
输出:2, nums = [2,2]
解释:函数应该返回新的长度 2, 并且 nums 中的前两个元素均为 2。你不需要考虑数组中超出新长度后面的元素。例如,函数返回的新长度为 2 ,而 nums = [2,2,3,3] 或 nums = [2,2,0,0],也会被视作正确答案。
示例 2:

输入:nums = [0,1,2,2,3,0,4,2], val = 2
输出:5, nums = [0,1,4,0,3]
解释:函数应该返回新的长度 5, 并且 nums 中的前五个元素为 0, 1, 3, 0, 4。注意这五个元素可为任意顺序。你不需要考虑数组中超出新长度后面的元素。


🍒解法一

class Solution:
    def removeElement(self, nums, val):
        l = r = 0
        for r, x in enumerate(nums):
            if x != val:
                nums[l] = x
                l += 1
        return l 

来自一位大佬的解答,本题主要使用了enumerate函数,之后使用下标r来进行索引判断与val相不相等
每次的判断可能会对长度l做出+1操作,最后返回的是l也就是长度了。


🍒题目二 28. 找出字符串中第一个匹配项的下标

给你两个字符串 haystack 和 needle ,请你在 haystack 字符串中找出 needle 字符串的第一个匹配项的下标(下标从 0 开始)。如果 needle 不是 haystack 的一部分,则返回 -1 。

示例 1:

输入:haystack = “sadbutsad”, needle = “sad”
输出:0
解释:“sad” 在下标 0 和 6 处匹配。
第一个匹配项的下标是 0 ,所以返回 0 。
示例 2:

输入:haystack = “leetcode”, needle = “leeto”
输出:-1
解释:“leeto” 没有在 “leetcode” 中出现,所以返回 -1 。

提示:

1 <= haystack.length, needle.length <= 104
haystack 和 needle 仅由小写英文字符组成


🍒解法一

class Solution(object):
    def strStr(self, haystack, needle):
        """
        :type haystack: str
        :type needle: str
        :rtype: int
        """
        for i in range(0,len(haystack)-len(needle)+1):
            if haystack[i:i+len(needle)] == needle:
                return i 
        return -1

官方的做法,很妙

方法一:暴力匹配
思路及算法
我们可以让字符串 needle 与字符串 haystack 的所有长度为 m 的子串均匹配一次。
为了减少不必要的匹配,我们每次匹配失败即立刻停止当前子串的匹配,对下一个子串继续匹配。如果当前子串匹配成功,我们返回当前子串的开始位置即可。如果所有子串都匹配失败,则返回 −1。

在这里插入图片描述

🍒题目三 35. 搜索插入位置

给定一个排序数组和一个目标值,在数组中找到目标值,并返回其索引。如果目标值不存在于数组中,返回它将会被按顺序插入的位置。

请必须使用时间复杂度为 O(log n) 的算法。

示例 1:

输入: nums = [1,3,5,6], target = 5
输出: 2
示例 2:

输入: nums = [1,3,5,6], target = 2
输出: 1
示例 3:

输入: nums = [1,3,5,6], target = 7
输出: 4

🍒解法一

class Solution:
  def searchInsert(self, nums, target):
      head = 0
      n = len(nums)
      tail = n -1 
      while head <= tail:
          tar = nums[(tail + head)//2]
          if tar > target:
              tail = (tail + head)// 2 -1
          elif tar < target:
              head = (tail + head)// 2 +1 
          else:
              return (tail + head)//2 
      return  (tail + head)//2 +1

某位大佬的实现的二分法


请添加图片描述

挑战与创造都是很痛苦的,但是很充实。

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

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

相关文章

MyBatis-Plus代码自动生成

前言 这是一段使用 MyBatis-Plus 自动生成代码的示例代码。MyBatis-Plus 是一个优秀的 ORM 框架&#xff0c;它在 MyBatis 的基础上进行了扩展和增强&#xff0c;提供了更加便捷、高效的数据库操作方式。在实际开发中&#xff0c;我们通常需要编写大量的 CRUD 操作代码&#x…

OpenCV官方教程中文版 —— 2D 直方图

OpenCV官方教程中文版 —— 2D 直方图 前言一、介绍二、OpenCV 中的 2D 直方图三、Numpy 中 2D 直方图四、绘制 2D 直方图 前言 本节我们会学习如何绘制 2D 直方图&#xff0c;我们会在下一节中使用到它。 一、介绍 在前面的部分我们介绍了如何绘制一维直方图&#xff0c;之…

TeamViewer

爱情就像两个拉皮筋的人&#xff0c;受伤的总是不愿放手的那一个&#xff01; TeamViewer – 远程连接软件 点击下载 电脑版就下载电脑 安卓版就下载安卓 苹果版就下苹果

bug:Chrome插件SwitchyOmega安装时程序包无效:“CRX_HEADER_INVALID“问题

bug&#xff1a;Chrome插件SwitchyOmega安装时程序包无效:“CRX_HEADER_INVALID“问题 1 解决 先说解决办法&#xff1a; 将下载的crx重命名为xxx.zip&#xff0c;然后解压打开chrome的开发者模式 点击加载已解压的应用程序&#xff0c;然后选择我们解压后的文件夹即可 安装成…

MyBatisPlus自动填充

文章目录 MyBatisPlus自动填充应用场景在实体类里面规定要填充的字段写处理器测试 MyBatisPlus自动填充 应用场景 我们往数据库里面插入一条记录&#xff0c;或者是更新一条记录的时候&#xff0c;往往需要有插入时间和更新时间&#xff0c;如果每条sql语句里面都这样写&…

Spring使用注解进行注入

目录 前言 一、属性注入 1.1 属性注入的优缺点分析 二、Setter注入 2.1 Setter注入优缺点分析 三、构造方法注入 3.1 构造注入的优缺点 四、Qualifier注解 五、Resource注解 六、Resource注解与Autowired注解的区别 前言 在之前我们就已经了解过了Spring依赖注入的方式&#x…

word页脚设置,页脚显示第几页共有几页设置步骤

word页脚设置&#xff0c;页脚显示第几页共有几页设置步骤&#xff1a; 具体步骤&#xff1a; 步骤1&#xff1a; 步骤1.1选择页脚---空白页脚 步骤1.2&#xff0c;在"[在此处键入]"&#xff0c;直接输入你需要的格式&#xff0c;如 “第页/共页” 步骤1.3选择第“…

基于ssm服装购物系统

功能如图所示 摘要 基于SSM框架的服装购物系统研究在当今数字化时代具有更为广泛的重要意义。首先&#xff0c;电子商务已成为商业领域的重要发展方向&#xff0c;尤其在全球范围内&#xff0c;服装零售商面临着不断增长的在线购物需求。这种研究能够帮助服装零售商迅速适应市场…

Failed to prepare the device for development

&#x1f468;&#x1f3fb;‍&#x1f4bb; 热爱摄影的程序员 &#x1f468;&#x1f3fb;‍&#x1f3a8; 喜欢编码的设计师 &#x1f9d5;&#x1f3fb; 擅长设计的剪辑师 &#x1f9d1;&#x1f3fb;‍&#x1f3eb; 一位高冷无情的编码爱好者 大家好&#xff0c;我是 DevO…

班级管理神器

哈喽&#xff0c;亲爱的小红书教育朋友们&#xff01;今天来分享一个重磅好物&#xff1a;班级查询系统&#xff01;是的&#xff0c;你没有听错&#xff0c;让我们的孩子们告别信息混乱&#xff0c;告别手动统计&#xff0c;迎接高效、智能的班级管理新时代&#xff01; 班级查…

appium+selenium自动化测试UI踩坑记录之--判断元素是否存在

判断应用程序元素是否存在&#xff0c;之前使用的代码如下&#xff0c;但是页面跳转后&#xff0c;通过xpath查找信息能查找到跳转前页面的内容&#xff0c;造成信息判断不准确。 # 从selenium.common.exceptions 模块导入 NoSuchElementException类from selenium.common.excep…

mysql主从搭建(gtid)

搭建mysql主从使用三台主机&#xff0c;主机信息如下 ip端口主机名角色10.1.60.803306rabbitmq04salve10.1.60.1143306rabbitmq01slave10.1.60.1153306rabbitmq02master 为每台主机修改主机名并配置hosts hostnamectl set-hostname rabbitmq04 vi /etc/hosts 10.1.60.114 …

【飞控调试】无人机电调哔-哔-哔-哔-哔...发出急促的响声

硬件 飞控&#xff1a;Pixhawk 6C mini 电调&#xff1a;好盈hobbywing Platinum 40A 固件&#xff1a;PX4 V1.13.3 问题 电调上电后&#xff0c;电机发出哔-哔-哔-哔-哔…发出急促的响声&#xff0c;进行电调校准也没用。 解决 在QGC里把SYS_USE_IO参数改成Disabled&…

Hyperledger Fabric搭建测试网络

本文使用的Fabric版本&#xff1a;V2.5.4 Ubuntu系统&#xff1a;16.04LTS 前序文章已经详细介绍了如何安装部署Hyperledger Fabric系统&#xff0c;这里不再赘述。本篇文章主要介绍如何使用Fabric的测试网络。在正式开始之前&#xff0c;有一点需要说明&#xff1a; Hyperled…

IndexError: Target 34 is out of bounds.

问题出现在训练用的标签处&#xff0c;标签超过范围&#xff0c;换了数据集后标签数发生改变&#xff0c;总而言之是目标分类数量超过了你所设置的标签数量的范围&#xff0c;归根结底是全连接参数没有改过来。找到label位置改一下数量

C# 图解教程 第5版 —— 第8章 类和继承

文章目录 8.1 类继承8.2 访问继承的成员&#xff08;*&#xff09;8.3 所有类都派生自 object 类8.4 屏蔽基类的成员8.5 基类访问8.6 使用基类的引用8.6.1 虚方法和覆写方法8.6.2 覆写标记为 override 的方法8.6.3 覆盖其他类型成员&#xff08;*&#xff09; 8.7 构造函数的执…

2011-2021年“第四期”数字普惠金融指数与上市公司匹配(根据省份匹配)/上市公司数字金融指数匹配

2011-2021年“第四期”数字普惠金融指数与上市公司匹配&#xff08;根据省份匹配&#xff09;/上市公司数字金融指数匹配 1、时间&#xff1a;2011-2021年 2、指标&#xff1a;股票代码、年份、行政区划代码、行业名称 、行业代码、所属省份、数字普惠金融指数、覆盖广度、使…

嵌入式学习5大误区,你中招了吗?

目录 误区1&#xff1a;错把自己当稚晖君 误区2&#xff1a;错误的学习方法 误区3&#xff1a;忽略时间成本 误区4&#xff1a;缺乏系统思维 误区5&#xff1a;追求完美主义 误区1&#xff1a;错把自己当稚晖君 稚晖君能够以一己之力创造一个个惊艳的产品&#xff0c;离不…

代码随想录算法训练营第三十四天 | LeetCode 860. 柠檬水找零、406. 根据身高重建队列、452. 用最少数量的箭引爆气球

代码随想录算法训练营第三十四天 | LeetCode 860. 柠檬水找零、406. 根据身高重建队列、452. 用最少数量的箭引爆气球 文章链接&#xff1a;柠檬水找零 根据身高重建队列 用最少数量的箭引爆气球 视频链接&#xff1a;柠檬水找零 根据身高重建队列 …

StarRocks 荣获 InfoWorld 2023 年最佳开源软件

近日&#xff0c;InfoWorld 公布了 2023 Bossie Awards 获奖名单&#xff0c;StarRocks 作为数据分析领域的明星项目&#xff0c;光荣入列。 InfoWorld 是一家具有全球影响力的信息技术媒体公司&#xff0c;每年都会根据软件对开源界的贡献&#xff0c;发布 Bossie Awards 榜单…