每周算法练习

1.删除有序数组中的重复项

给定一个排序数组,你需要在原地删除重复出现的元素,使得每个元素只出现一次,返回移除后数组的新长度。
不要使用额外的数组空间,你必须在原地修改输入数组并在使用 O(1) 额外空间的条件下完成。

当给定数组为空的时候就应该返回0
而且不能引入其他数组空间,那就是不能再使用一个新的数组来存放结果
还要不重复,数组中超出新长度后面的元素无视

那我们就可以用快慢指针的思想来解答这道题了

给定两个游标left和right
当给定数组的下标为left和right的值一样的话,就不管
当不一样的话,那我们就要做一个操作,就是把当前right下标的值给到left下一个下标
具体代码:

func removeDuplicates(nums []int) int {

 //如果是空切片,那就返回0

 if len(nums) == {

 return

 }

 //用两个标记来比较相邻位置的值

 //当一样的话,那就不管继续

 //当不一样的时候,就把right指向的值赋值给left下一位

 left, right := ,

 for ; right len(nums); right++ {

 if nums[left] == nums[right] {

 continue

 }

 left++

 nums[left] = nums[right]

 }

 fmt.Println(nums[:left+])

 return left +

}

2.快慢指针

概念

快慢指针就是存在两个指针,一个快指针,一个慢指针,两个指针每次移动的速度不一样,快的移动的快,慢的移动的慢。快慢指针中的快慢指的是移动的步长,即每次向前移动速度的快慢。例如可以让快指针每次沿链表向前移动2,慢指针每次向前移动1次。

应用

在这里插入图片描述

双指针

从头部与尾部同时进行,当两个下标的和小于目标值时,头部‘指针’向右移动,当两个下标和大于目标值时,尾部‘指针’向左移动,直到两个’指针’重合循环结束,可以看出,如果是乱序就没什么用处了

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值