Golang 数组 移除元素 双指针法 leetcode27 小记

2023-12-18 06:52

本文主要是介绍Golang 数组 移除元素 双指针法 leetcode27 小记,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

文章目录

  • 移除元素 leetcode27
    • 暴力解法
    • 双指针法
      • 1. 快慢指针
      • 2. 双向指针

移除元素 leetcode27

  go中数据类型的分类:
1.类型:int、float、bool、string、数组、结构体
2.引用类型:指针、切片、map、管道、接口

  由于切片为引用类型,其本质是基于数组完成的,因此我们操作切片可以理解为操作底层的数组。

暴力解法

  第一个for循环遍历切片,第二个for循环将部分数组前移

双指针法

1. 快慢指针

  双指针法(快慢指针法): 通过一个快指针慢指针一个for循环下完成两个for循环的工作。
  在c中erase函数删除元素是将数组中当前位置后面的元素都向前移动一位,其时间复杂度为O(n)
  而go中切片的截取(s[:]和append方法),都是通过修改指向底层的数组的指针实现,对于删除头部和尾部元素的时间复杂度为O(1),中间元素的删除则同样为O(n)
  完整代码如下,包含学习过程

package mainimport "fmt"func main() {nums := []int{3, 2, 2, 3}val := 3c := removeElement(nums, val)fmt.Println(c)fmt.Println(nums)
}// 暴力解法
/*func removeElement(nums []int, val int) int {length := len(nums)if length == 0 {return 0}c := lengthfor i, v := range nums {if v == val {putOff(nums, i, val, length)c--}for nums[i] == val {putOff(nums, i, val, length)c--}}if nums[0] == val {return 0}return c
}func putOff(nums []int, i int, val int, length int) {if i == length-1 {nums[length-1] = val - 1return}nums[i] = nums[i+1]putOff(nums, i+1, val, length)
}*/// 双指针法 这里的解法还是有问题,在对应fast指针更新时,不作更新,只进行fast的右移,可以减少代码量
/*func removeElement(nums []int, val int) int {var fast, slow = 0, 0length := len(nums)for fast < length {for nums[fast] == val {fast++if fast == length {return length - fast + slow}}//if nums[slow] == val {////}nums[slow] = nums[fast]slow++fast++}return length - fast + slow
}*/// 改进双指针,最终版
func removeElement(nums []int, val int) int {var fast, slow = 0, 0length := len(nums)for fast < length {if nums[fast] != val { //如果fast对应值不是val,则可以写入nums[slow] = nums[fast]slow++}//如果fast对应等于val,则fast移位,不进行更新操作fast++}return slow
}

2. 双向指针

//相向双指针法
func removeElement(nums []int, val int) int {// 有点像二分查找的左闭右闭区间 所以下面是<=left := 0right := len(nums) - 1for left <= right {// 不断寻找左侧的val和右侧的非val 找到时交换位置 目的是将val全覆盖掉for left <= right && nums[left] != val {left++}for left <= right && nums[right] == val {right--}//各自找到后开始覆盖 覆盖后继续寻找if left < right {nums[left] = nums[right]left++right--}}fmt.Println(nums)return left
}

这篇关于Golang 数组 移除元素 双指针法 leetcode27 小记的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/507454

相关文章

JavaScript对象转数组的三种方法实现

《JavaScript对象转数组的三种方法实现》本文介绍了在JavaScript中将对象转换为数组的三种实用方法,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友... 目录方法1:使用Object.keys()和Array.map()方法2:使用Object.entr

Rust 智能指针的使用详解

《Rust智能指针的使用详解》Rust智能指针是内存管理核心工具,本文就来详细的介绍一下Rust智能指针(Box、Rc、RefCell、Arc、Mutex、RwLock、Weak)的原理与使用场景,... 目录一、www.chinasem.cnRust 智能指针详解1、Box<T>:堆内存分配2、Rc<T>:

JavaScript中比较两个数组是否有相同元素(交集)的三种常用方法

《JavaScript中比较两个数组是否有相同元素(交集)的三种常用方法》:本文主要介绍JavaScript中比较两个数组是否有相同元素(交集)的三种常用方法,每种方法结合实例代码给大家介绍的非常... 目录引言:为什么"相等"判断如此重要?方法1:使用some()+includes()(适合小数组)方法2

Java中数组与栈和堆之间的关系说明

《Java中数组与栈和堆之间的关系说明》文章讲解了Java数组的初始化方式、内存存储机制、引用传递特性及遍历、排序、拷贝技巧,强调引用数据类型方法调用时形参可能修改实参,但需注意引用指向单一对象的特性... 目录Java中数组与栈和堆的关系遍历数组接下来是一些编程小技巧总结Java中数组与栈和堆的关系关于

把Python列表中的元素移动到开头的三种方法

《把Python列表中的元素移动到开头的三种方法》在Python编程中,我们经常需要对列表(list)进行操作,有时,我们希望将列表中的某个元素移动到最前面,使其成为第一项,本文给大家介绍了把Pyth... 目录一、查找删除插入法1. 找到元素的索引2. 移除元素3. 插入到列表开头二、使用列表切片(Lis

全面解析Golang 中的 Gorilla CORS 中间件正确用法

《全面解析Golang中的GorillaCORS中间件正确用法》Golang中使用gorilla/mux路由器配合rs/cors中间件库可以优雅地解决这个问题,然而,很多人刚开始使用时会遇到配... 目录如何让 golang 中的 Gorilla CORS 中间件正确工作一、基础依赖二、错误用法(很多人一开

golang程序打包成脚本部署到Linux系统方式

《golang程序打包成脚本部署到Linux系统方式》Golang程序通过本地编译(设置GOOS为linux生成无后缀二进制文件),上传至Linux服务器后赋权执行,使用nohup命令实现后台运行,完... 目录本地编译golang程序上传Golang二进制文件到linux服务器总结本地编译Golang程序

Java中的数组与集合基本用法详解

《Java中的数组与集合基本用法详解》本文介绍了Java数组和集合框架的基础知识,数组部分涵盖了一维、二维及多维数组的声明、初始化、访问与遍历方法,以及Arrays类的常用操作,对Java数组与集合相... 目录一、Java数组基础1.1 数组结构概述1.2 一维数组1.2.1 声明与初始化1.2.2 访问

golang版本升级如何实现

《golang版本升级如何实现》:本文主要介绍golang版本升级如何实现问题,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录golanwww.chinasem.cng版本升级linux上golang版本升级删除golang旧版本安装golang最新版本总结gola

golang中reflect包的常用方法

《golang中reflect包的常用方法》Go反射reflect包提供类型和值方法,用于获取类型信息、访问字段、调用方法等,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值... 目录reflect包方法总结类型 (Type) 方法值 (Value) 方法reflect包方法总结