当前位置: 首页 > news >正文

2024-04-03-代码随想录算法训练营第一天[LeetCode704二分查找、LeetCode27移除元素]

文章目录

  • 第一题
    • 解法一[左闭右开]
    • 解法二[左闭右闭]
    • 总结
  • 第二题
    • 解法一[暴力解法]
    • 解法二[双指针法]
    • 总结

第一题

LeetCode704二分查找

解法一[左闭右开]

class Solution {
public:int search(vector<int>& nums, int target) {int size = nums.size();int right = size;int left = 0;while (left < right){int middle = left + ((right - left) / 2);//防止溢出if (nums[mid] == target){return mid;}else if (nums[mid] > target){right = mid;  }else{left = mid + 1;}}return -1;}
};

解法二[左闭右闭]

class Solution {
public:int search(vector<int>& nums, int target) {int size = nums.size();int right = size - 1;int left = 0;while (left <= right){int mid = (right + left) / 2;if (nums[mid] == target){return mid;}else if (nums[mid] > target){right = mid - 1;  }else{left = mid + 1;}   }return -1;}
};

总用时:十五分钟

总结

前几天做过一次了,这是第二次刷这题,还算是比较顺利的写出来这两种方法,总体看来左闭右开与左闭右闭的区别在于是否能取到right下标的值。几个关键的区别的地方:

  • 初始right在左闭右开取数组长度,在左闭右闭时取数组最大下标。

  • 左闭右开在while时不需要等号,因为[a, b),当b = a + 1数组就已经遍历完成。

  • 左闭右开在判断nums[mid] < target时直接将right = mid即可,因为mid已经判断完毕,mid在这种方式是取不到的所以最新的右下标等于mid,而左闭右闭时right = mid - 1,此时这种方式可以取到,将right指向新的未判断的下标。

第二题

LeetCode27移除元素

解法一[暴力解法]

class Solution {
public:int removeElement(vector<int>& nums, int val) {// 暴力解法int n = nums.size();for (int i = 0; i < n; i++){if (nums[i] == val){for (int j = i + 1; j < n; j++){nums[j - 1] = nums[j];}i--;n--;}}return n;}
};

解法二[双指针法]

class Solution {
public:int removeElement(vector<int>& nums, int val) {int n = nums.size();int right = 0;int left = 0;for (int right = 0; right < n; right++){// 找第一个不等于的值放到数组前if (nums[right] != val){nums[left++] = nums[right];}}return left;}
};

用时:30分钟

总结

目前暴力解法可以通过,暴力解法不太熟悉,主要卡在没有更新数组长度,导致超时,这是因为加入末尾有需要删除的值,将会拷贝很多份,如果不实时更新数组长度,会陷入死循环导致超时。

双指针法:好像还没那么难,这次直接写出来通过了,主要在于右指针找第一个不为val的值放入数组前面,同时更新左指针。

待完成:35.搜索插入位置 和 34. 在排序数组中查找元素

删除的值,将会拷贝很多份,如果不实时更新数组长度,会陷入死循环导致超时。

双指针法:好像还没那么难,这次直接写出来通过了,主要在于右指针找第一个不为val的值放入数组前面,同时更新左指针。

待完成:35.搜索插入位置 和 34. 在排序数组中查找元素

相关文章:

2024-04-03-代码随想录算法训练营第一天[LeetCode704二分查找、LeetCode27移除元素]

文章目录 第一题解法一[左闭右开]解法二[左闭右闭]总结 第二题解法一[暴力解法]解法二[双指针法]总结 第一题 LeetCode704二分查找 解法一[左闭右开] class Solution { public:int search(vector<int>& nums, int target) {int size nums.size();int right size…...

[Go运行问题]/lib/x86_64-linux-gnu/libc.so.6: version `GLIBC_xx‘ not found

问题描述 在一台ubuntu 20的机器上通过go 编译生成的可执行程序(使用了cgo)&#xff0c;在其他ubuntu机器上运行时出现如下问题 /lib/x86_64-linux-gnu/libc.so.6: version GLIBC_2.32 not found 问题分析 因为go代码里的依赖库使用到了sndfile&#xff0c;它必须使用cgo了…...

matrix-breakout-2-morpheus 靶机渗透

信息收集&#xff1a; 1.nmap存活探测&#xff1a; nmap -sn -r 192.168.10.1/24 Starting Nmap 7.94SVN ( https://nmap.org ) at 2024-04-06 12:13 CST Nmap scan report for 192.168.10.1 Host is up (0.00056s latency). MAC Address: 00:50:56:C0:00:08 (VMware) Nmap…...

爬虫 新闻网站 以湖南法治报为例(含详细注释) V1.0

目标网站&#xff1a;湖南法治报 爬取目的&#xff1a;为了获取某一地区更全面的在湖南法治报已发布的宣传新闻稿&#xff0c;同时也让自己的工作更便捷 环境&#xff1a;Pycharm2021&#xff0c;Python3.10&#xff0c; 安装的包&#xff1a;requests&#xff0c;csv&#xff…...

物联网实战--入门篇之(十)安卓QT--后端开发

目录 一、项目配置 二、MQTT连接 三、数据解析 四、数据更新 五、数据发送 六、指令下发 一、项目配置 按常规新建一个Quick空项目后&#xff0c;我们需要对项目内容稍微改造、规划下。 首先根据我们的需要在.pro文件内添加必要的模块&#xff0c;其中quick就是qml了&…...

[Java]网络编程

网络编程概述 计算机网络&#xff1a; 把分布在不同地理区域的具有独立功能的计算机,通过通信设备与线路连接起来&#xff0c;由功能完善的软件实现资源共享和信息传递的系统。 Java是 Internet 上的语言&#xff0c;它从语言级上提供了对网络应用程序的支持&#xff0c;程序…...

重读Java设计模式: 适配器模式解析

引言 在软件开发中&#xff0c;经常会遇到不同接口之间的兼容性问题。当需要使用一个已有的类&#xff0c;但其接口与我们所需的不兼容时&#xff0c;我们可以通过适配器模式来解决这一问题。适配器模式是一种结构型设计模式&#xff0c;它允许接口不兼容的类之间进行合作。本…...

MySQL面试题系列-9

MySQL是一个关系型数据库管理系统&#xff0c;由瑞典 MySQL AB 公司开发&#xff0c;属于 Oracle 旗下产品。MySQL是最流行的关系型数据库管理系统之一&#xff0c;在 WEB 应用方面&#xff0c;MySQL是最好的RDBMS (Relational Database Management System&#xff0c;关系数据…...

书生·浦语训练营二期第二次笔记

文章目录 1. 部署 InternLM2-Chat-1.8B 模型进行智能对话1.1 配置环境1.2 下载 InternLM2-Chat-1.8B 模型 2. 实战&#xff1a;部署实战营优秀作品 八戒-Chat-1.8B 模型2.1 配置基础环境2.2 使用 git 命令来获得仓库内的 Demo 文件&#xff1a;2.3 下载运行 Chat-八戒 Demo 3. …...

python_3

文章目录 题目运行结果模式A模式B模式C模式D 题目 mode input("请选择模式:") n int(input("请输入数字:"))if mode "A" or mode "a":# 模式A n:输入的层数 i:当前的层数# 每行数字循环次数 ifor i in range(1, n 1):for j in r…...

【Python】 使用Apache Tika和Python实现zip、csv、xls等多格式文件文本内容提取

时间的电影 结局才知道 原来大人已没有童谣 最后的叮咛 最后的拥抱 我们红着眼笑 我们都要把自己照顾好 好到遗憾无法打扰 好好的生活 好好的变老 好好假装我 已经把你忘掉 &#x1f3b5; 五月天《好好》 在进行数据分析、搜索引擎优化或任何需要处理大量…...

C语言如何将多维数组名作为函数参数?

一、问题 ⼦函数执⾏时&#xff0c;整个多维数组是由主函数决定的&#xff0c;这时就要把多维数组的数组名作为函数参数传递给⼦函数。那么在C程序中&#xff0c;怎样将多维数组名作函数参数进⾏传递&#xff1f; 二、解答 以⼆维数组为例&#xff0c;其格式如下。 形参定义&…...

2013年认证杯SPSSPRO杯数学建模C题(第二阶段)公路运输业对于国内生产总值的影响分析全过程文档及程序

2013年认证杯SPSSPRO杯数学建模 C题 公路运输业对于国内生产总值的影响分析 原题再现&#xff1a; 交通运输作为国民经济的载体&#xff0c;沟通生产和消费&#xff0c;在经济发展中扮演着极其重要的角色。纵观几百年来交通运输与经济发展的相互关系&#xff0c;生产水平越高…...

《LeetCode力扣练习》代码随想录——二叉树(合并二叉树---Java)

《LeetCode力扣练习》代码随想录——二叉树&#xff08;合并二叉树—Java&#xff09; 刷题思路来源于 代码随想录 617. 合并二叉树 二叉树-前序遍历 /*** Definition for a binary tree node.* public class TreeNode {* int val;* TreeNode left;* TreeNode right;* TreeNode…...

openstack云计算(二)——使用Packstack安装器安装一体化OpenStack云平台

初步掌握OpenStack快捷安装的方法。掌握OpenStack图形界面的基本操作。 一【准备阶段】 &#xff08;1&#xff09;准备一台能够安装OpenStack的实验用计算机&#xff0c;建议使用VMware虚拟机。 &#xff08;2&#xff09;该计算机应安装CentOS 7&#xff0c;建议采用CentO…...

Flutter Don‘t use ‘BuildContext‘s across async gaps.

Flutter提示Don‘t use ‘BuildContext‘s across async gaps.的解决办法—flutter里state的mounted属性...

基于SSM+Jsp+Mysql的个性化影片推荐系统

开发语言&#xff1a;Java框架&#xff1a;ssm技术&#xff1a;JSPJDK版本&#xff1a;JDK1.8服务器&#xff1a;tomcat7数据库&#xff1a;mysql 5.7&#xff08;一定要5.7版本&#xff09;数据库工具&#xff1a;Navicat11开发软件&#xff1a;eclipse/myeclipse/ideaMaven包…...

循环队列的实现及应用——桶排序bucket_sort、基数排序radix_sort

一、循环队列的实现 代码解释 1、完成初始化 2、定义方法 3、测试实例 4、完整代码 class AQueue:def __init__(self, size=10):self.__mSize = sizeself.__front=0self.__rear = 0self.__listArray = [None] * size#清空元素def clear(self):self.__front = 0self.__rear =…...

ubuntu16如何使用高版本cmake

1.引言 最近在尝试ubuntu16.04下编译开源项目vsome&#xff0c;发现使用apt命令默认安装cmake的的版本太低。如下 最终得知&#xff0c;ubuntu16默认安装确实只能到3.5.1。解决办法只能是源码安装更高版本。 2.源码下载3.20 //定位到opt目录 cd /opt 下载 wget https://cmak…...

电商-广告投放效果分析(KMeans聚类、数据分析-pyhton数据分析

电商-广告投放效果分析&#xff08;KMeans聚类、数据分析&#xff09; 文章目录 电商-广告投放效果分析&#xff08;KMeans聚类、数据分析&#xff09;项目介绍数据数据维度概况数据13个维度介绍 导入库&#xff0c;加载数据数据审查相关性分析数据处理建立模型聚类结果特征分析…...

基于Tauri与React构建多AI模型协作桌面应用Talkio的技术实践

1. 项目概述&#xff1a;一个让AI“开会”的桌面应用 如果你和我一样&#xff0c;每天要和多个AI模型打交道——用ChatGPT写文案&#xff0c;让Claude审代码&#xff0c;找DeepSeek查资料——那你一定体会过在不同网页标签间反复横跳的麻烦。更别提有时候&#xff0c;你其实想…...

量子计算与深度学习结合解决Frenkel激子模拟难题

1. 量子计算与Frenkel激子模拟的背景与挑战量子计算利用量子比特的叠加和纠缠特性&#xff0c;为解决复杂量子系统模拟问题提供了全新途径。在材料科学领域&#xff0c;Frenkel激子作为典型的局域化光学激发&#xff0c;其哈密顿量的求解对理解有机固体的光电性质至关重要。传统…...

在Taotoken控制台中清晰追踪项目成本与各模型消耗明细

&#x1f680; 告别海外账号与网络限制&#xff01;稳定直连全球优质大模型&#xff0c;限时半价接入中。 &#x1f449; 点击领取海量免费额度 在Taotoken控制台中清晰追踪项目成本与各模型消耗明细 对于使用大模型API进行开发的团队或个人而言&#xff0c;成本控制与费用透明…...

Crux终端模拟器:现代开发者工作流的GPU加速与原生集成实践

1. 项目概述&#xff1a;一个面向开发者的现代终端体验如果你和我一样&#xff0c;每天有超过一半的工作时间是在终端里度过的&#xff0c;那么你肯定对终端工具有着近乎苛刻的要求。它必须快、必须稳、必须能让你在键盘上“指哪打哪”&#xff0c;而不是在鼠标和键盘之间来回切…...

掌握AI教材生成技巧,借助低查重工具,3天完成50万字教材编写!

编写教材的困境与 AI 解决方案 谁没有遇到过编写教材时的框架难题呢&#xff1f;面对空白的文档&#xff0c;常常会呆坐半个小时&#xff0c;完全不知从何下手——先解释概念好&#xff0c;还是先引用案例&#xff1f;章节该根据逻辑划分&#xff0c;还是根据课时来安排&#…...

OpenClaw安全审计:AI驱动的自动化配置检查与隐私保护实践

1. 项目概述与核心价值 最近在折腾我的 OpenClaw 机器人&#xff0c;这玩意儿功能是越来越强大了&#xff0c;能接各种消息渠道&#xff0c;还能调用五花八门的工具。但功能一多&#xff0c;配置就复杂&#xff0c;安全问题也跟着冒头。比如&#xff0c;你是不是也担心过 API 密…...

AI平台竞争中的合谋与网络效应:市场博弈的底层逻辑分析

1. 项目概述&#xff1a;当AI平台开始“默契”时&#xff0c;市场会发生什么&#xff1f; 最近和几位做投资和产品战略的朋友聊天&#xff0c;话题总绕不开一个现象&#xff1a;几个头部的AI大模型平台&#xff0c;无论是定价策略、功能迭代节奏&#xff0c;还是对开发者的扶持…...

生成式AI重塑智能座舱:从多模态交互到车端部署的工程实践

1. 项目概述&#xff1a;当生成式AI“坐”进驾驶舱最近几年&#xff0c;生成式AI的浪潮席卷了各行各业&#xff0c;从写诗作画的ChatGPT、Midjourney&#xff0c;到能编程的Copilot&#xff0c;大家已经见怪不怪了。但你可能没太留意&#xff0c;这股风其实早就吹进了汽车行业&…...

在 Taotoken 上如何清晰观测各模型 API 用量与成本

&#x1f680; 告别海外账号与网络限制&#xff01;稳定直连全球优质大模型&#xff0c;限时半价接入中。 &#x1f449; 点击领取海量免费额度 在 Taotoken 上如何清晰观测各模型 API 用量与成本 对于团队管理者或独立开发者而言&#xff0c;在集成多个大模型服务时&#xff…...

CANNBot Simulator V2参考文档

Simulator V2 Reference 【免费下载链接】cannbot-skills CANNBot 是面向 CANN 开发的用于提升开发效率的系列智能体&#xff0c;本仓库为其提供可复用的 Skills 模块。 项目地址: https://gitcode.com/cann/cannbot-skills Read this file when the question is specif…...