代码随想录day01

数组理论基础

● 思维不难,主要是考察对代码的掌控能力
● 内存中的存储方式:存放在连续内存空间上的相同类型数据的集合
● 数组可以通过下标索引获取到下标对应的数据
● 数组下标从0开始
● 因为内存空间地址连续,因此删除或增加元素的时候,难免移动其他元素地址
● Java中的二维数组,每一行连续,头结点地址没有规则

704.二分查找

● 力扣题目链接
● 给定一个 n 个元素有序的(升序)整型数组 nums 和一个目标值 target  ,写一个函数搜索 nums 中的 target,如果目标值存在返回下标,否则返回 -1。

思路

● 二分查找逻辑,两种方式,左闭右闭或者左闭右开
● 时间复杂度O(n) 空间复杂度O(logn)
● 为什么不是 m = (i + j) / 2?
  ○ 因为 i + j 可能很大,二进制表示的数字高位一旦变成1,就变成负数了,做除法无法改变符号,而无符号右移可以,就是除掉二后还是int,但不除可能最高位是1,就导致符号问题
  ○ Java中,整数都是有符号的,最高位是符号位,0表示正数,1表示负数

代码

// 方法一:左闭右闭写法
class Solution {public int search(int[] nums, int target) {int l = 0;int r = nums.length - 1; // 这里右边闭,因此在r处的也可能是答案int m;while (l <= r) { // 因为r处的可能是答案,所以l=r时还要再看看,不能返回-1m = (l + r) >>> 1;if (nums[m] < target) {l = m + 1; // m处元素小,那继续往右找} else if (nums[m] > target) {r = m - 1; //m处元素大,那继续往左找} else {return m; // 找到了}}return -1; // 没找到,返回-1}
}// 方法二:左闭右开写法
class Solution {public int search(int[] nums, int target) {int l = 0;int r = nums.length; // 这里r取到了数组末尾的后一位,因此r的位置一定不是答案int m;while (l < r) { // 不用管l=r,因为r的位置一定不是答案,l=r时可以直接结束循环m = (l + r) >>> 1;if (nums[m] < target) {l = m + 1; // m处元素小,和之前一样} else if (nums[m] > target) {r = m; // m处元素大,让r=m即可,如果这里r=m-1,可能导致原来m-1处的元素少判定一次,有问题// -1 0 3 7 9 12 找7,m=3 l=7 m=9 然后r需要是9,不能是7,不然返回-1了} else {return m;}}return -1;}
}

27. 移除元素

● 力扣题目链接
● 给你一个数组 nums 和一个值 val,你需要 原地 移除所有数值等于 val 的元素,并返回移除后数组的新长度。
● 不要使用额外的数组空间,你必须仅使用 O(1) 额外空间并原地修改输入数组。
● 元素的顺序可以改变。你不需要考虑数组中超出新长度后面的元素。

思路

● 双指针法,一个指针遍历数组,如果遇到不等于tar,就更换元素

代码

class Solution {public int removeElement(int[] nums, int val) {int res = 0; // 初始长度为0for (int i = 0; i < nums.length; i++) { // 遍历一遍数组if (nums[i] != val) { // 如果不等于valnums[res++] = nums[i]; // 把i处元素放到res的位置,然后res+1}}return res; // 最后返回res}
}
// 优化为相向双指针,避免要删除的元素在最右侧导致要移动很多元素
class Solution {public int removeElement(int[] nums, int val) {int l = 0; int r = nums.length - 1;while (l <= r) { // 等于也要看,用l遍历,要么自己走,要么是r交换过来的if (nums[l] == val) {nums[l] = nums[r];r--; // 移动r,因为这个一定是val,看过了,继续走} else {l++; // 不是val,移动l}}return l; // 最后返回l,就是新数组的长度}
}

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

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

相关文章

现代C++中的从头开始深度学习:【4/8】梯度下降

一、说明 在本系列中&#xff0c;我们将学习如何仅使用普通和现代C编写必须知道的深度学习算法&#xff0c;例如卷积、反向传播、激活函数、优化器、深度神经网络等。 在这个故事中&#xff0c;我们将通过引入梯度下降算法来介绍数据中 2D 卷积核的拟合。我们将使用卷积和上一个…

大数据技术之Hadoop:HDFS集群安装篇(三)

目录 分布式文件系统HDFS安装篇 一、为什么海量数据需要分布式存储 二、 分布式的基础架构分析 三、 HDFS的基础架构 四 HDFS集群环境部署 4.1 下载安装包 4.2 集群规划 4.3 上传解压 4.4 配置HDFS集群 4.5 准备数据目录 4.6 分发hadoop到其他服务器 4.7 配置环境变…

OpenStack监控工具

OpenStack是一个开源的云计算管理平台项目&#xff0c;是一系列软件开源项目的组合。由NASA和Rackspace合作研发并发起&#xff0c;以Apache许可证&#xff08;Apache软件基金会发布的一个自由软件许可证&#xff09;授权。 OpenStack为私有云和公有云提供可扩展的弹性的云计算…

rancher证书过期,更新操作

看着比其他的都靠谱&#xff0c;我这里转载一下&#xff0c;以变下次找不到了 http://t.csdn.cn/p1QLU

Cadvisor+InfluxDB+Grafan+Prometheus(详解)

目录 一、CadvisorInfluxDBGrafan案例概述 &#xff08;一&#xff09;Cadvisor Cadvisor 产品特点&#xff1a; &#xff08;二&#xff09;InfluxDB InfluxDB应用场景&#xff1a; InfluxDB主要功能&#xff1a; InfluxDB主要特点&#xff1a; &#xff08;三&#…

·[K8S:使用calico网络插件]:解决集群节点NotReady问题

文章目录 一&#xff1a;安装calico&#xff1a;1.1&#xff1a;weget安装Colico网络通信插件&#xff1a;1.2&#xff1a;修改calico.yaml网卡相关配置&#xff1a;1.2.1&#xff1a;查看本机ip 网卡相关信息&#xff1a;1.2.2&#xff1a;修改calico.yaml网卡interface相关信…

深度解读|一站式ABI平台 Smartbi Insight V11 能力再升级

纵观过去&#xff0c;我们发现汽车和BI的发展有异曲同工之妙。 100来年&#xff0c;汽车的动力从蒸汽到燃油再到新能源&#xff0c;汽车的操控方式从手动到自动再到智能无人驾驶。而在BI领域&#xff0c;自1958年BI的概念提出后&#xff0c;底层数据准备从报表开发、Cube多维模…

【CI/CD】Git Flow 分支模型

Git Flow 分支模型 1.前言 Git Flow 模型&#xff08;本文所阐述的分支模型&#xff09;构思于 2010 年&#xff0c;也就是 Git 诞生后不久&#xff0c;距今已有 10 多年。在这 10 多年中&#xff0c;Git Flow 在许多软件团队中大受欢迎。 在这 10 多年里&#xff0c;Git 本身…

最大子数组和【力扣53】

一、解题思路 Max[i]表示&#xff1a;以nums[i]为开头的所有连续子数组和的最大值。 由此可以推出Max[i-1]和Max[i]的关系&#xff1a; 若Max[i]>0&#xff1a;Max[i-1]nums[i-1]Max[i]&#xff1b; 否则&#xff1a;Max[i-1]nums[i-1]&#xff1b; 则ansMAX&#xff0…

java try-with-resources自动关闭资源

try-with-resources 是 Java 7 引入的一种语法&#xff0c;用于自动关闭实现了 AutoCloseable 接口的资源。它可以简化代码中关闭资源的操作&#xff0c;确保资源得到正确释放&#xff0c;避免内存泄漏。 使用 try-with-resources 的语法如下&#xff1a; try (资源的声明和初…

RISC-V走向开放服务器规范

原文&#xff1a;RISC-V Moving Toward Open Server Specification 作者&#xff1a;Agam Shah 转载自&#xff1a;https://www.hpcwire.com/2023/07/24/risc-v-moving-toward-open-server-specification/ 中文翻译&#xff1a; 2023年7月24日 RISC-V International目前正…

亚马逊 EC2服务器下部署java环境

1. jdk 1.8 安装 1.1 下载jdk包 官网 Java Downloads | Oracle tar.gz 包 下载下来 1.2 本地连接 服务器 我用的是亚马逊的ec2 系统是 ubuntu 的 ssh工具是 Mobaxterm , 公有dns 创建实例时的秘钥 链接 Mobaxterm 因为使用的 ubuntu 所以登录的 名称 就是 ubuntu 然后 …

ts项目中引入js包,如vue-simple-uploader

有些包如vue-simple-uploader&#xff0c;使用npm下载后&#xff0c;npm仓库中没有对应的types类型声明&#xff0c;会报错&#xff0c;没有找到对应的types类型文件。 解决&#xff1a; 在项目根目录下&#xff0c;创建自定义的类型声明文件&#xff0c;如&#xff0c;self-…

【Ubuntu】简化反向代理和个性化标签页体验

本文将介绍如何使用Docker部署Nginx Proxy Manager和OneNav&#xff0c;两个功能强大且易用的工具。Nginx Proxy Manager用于简化和管理Nginx反向代理服务器的配置&#xff0c;而OneNav则提供个性化的新标签页体验和导航功能。通过本文的指导&#xff0c;您将学习如何安装和配置…

vue组件通信的方式?

父子通信&#xff1a; 1、父传子&#xff1a;在父组件的子组件标签绑定一个自定义属性&#xff0c;子组件通过props获取父组件传递的数据。 //父 <child :data"list" del"idx > list.splice(idx, 1)" ref"child" :isShow.sync"isS…

Redis可以用作数据库吗?它的适用场景是什么?

是的&#xff0c;Redis可以用作数据库。虽然Redis通常被认为是一个内存数据库&#xff08;in-memory database&#xff09;&#xff0c;但它也可以通过持久化机制将数据保存在磁盘上&#xff0c;以便在重启后恢复数据。 Redis的适用场景包括但不限于以下几个方面&#xff1a; …

程序使用Microsoft.XMLHTTP对象请求https时出错解决

程序中使用Microsoft.XMLHTTP组件请求https时出现如下错误&#xff1a; 出错程序代码示例&#xff1a; strUrl "https://www.xxx.com/xxx.asp?id11" dim objXmlHttp set objXmlHttp Server.CreateObject("Microsoft.XMLHTTP") objXmlHttp.open "…

电脑关机程序

//关机程序 1、电脑运行起来后&#xff0c;1分钟内关机。 2、如果输入&#xff1a;我是猪。就取消关机。 #include<stdio.h> #include<string.h> int main() { char input[20] { 0 }; system("shutdown -s -t 60"); again: printf(&quo…

Cesium相机理解

关于cesium相机&#xff0c;包括里面内部原理网上有很多人讲的都很清楚了&#xff0c;我感觉这两个人写的都挺好得&#xff1a; 相机 Camera | Cesium 入门教程 (syzdev.cn) Cesium中的相机—setView&lookAtTransform_cesium setview_云上飞47636962的博客-CSDN博客上面这…

【Linux】进程间通信——system V共享内存

目录 写在前面的话 System V共享内存原理 System V共享内存的建立 代码实现System V共享内存 创建共享内存shmget() ftok() 删除共享内存shmctl() 挂接共享内存shmat() 取消挂接共享内存shmdt() 整体通信流程的实现 写在前面的话 上一章我们讲了进程间通信的第一种方式…