【题目】
示例1
给定数组 nums = [1,1,2],
输出:
函数应该返回新的长度 2, 并且原数组 nums 的前两个元素被修改为 1, 2。
你不需要考虑数组中超出新长度后面的元素。
_
示例2
给定 nums = [0,0,1,1,1,2,2,3,3,4],
输出:
函数应该返回新的长度 5, 并且原数组 nums 的前五个元素被修改为 0, 1, 2, 3, 4。
你不需要考虑数组中超出新长度后面的元素。
【做前思考】
首先我想到的方法是快慢双指针的算法,但是代码发现总有些逻辑问题,偷瞄了一眼答案,厉害
思路: 初始快指针f比慢指针s快1,若nums[f]=nums[s];快指针继续+1,
直到nums[f] !=nums[s];将nums[f]赋值给nums[s+1]。
【代码】
class Solution(object):
def removeDuplicates(self,nums):
'''
:param nums: List[int]
:return: int
'''
l = len(nums)
if l <= 1:
return l
s = 0
for f in range(1,len(nums)):
if nums[s] != nums[f]:
s += 1
nums[s] = nums[f]
nums = nums[:s+1]
print("内部nums:",nums)
return s+1
#测试
nums = [0,0,1,1,1,2,2,3,3,4]
print(Solution().removeDuplicates(nums))
print("Class外的nums:",nums)
【结果】
输出结果:
内部nums: [0, 1, 2, 3, 4]
5
Class外的nums: [0, 1, 2, 3, 4, 2, 2, 3, 3, 4]
![](https://i-blog.csdnimg.cn/blog_migrate/77837c3ef3ee4f8adfe60825294c2e90.png)
【收获】
-
有个问题是为什么Class外的nums可以修改nums的元素值,但是不能改变nums的数组长度?
-
第二个收获是学会了写博客时改变插入图片比例的方法。
这次写博客,翻看之前写的博客图片比例真让人很难受,终于去找了下用markdown怎么样缩小插入图片的比例原文链接
#以下是我的插入图片链接代码
<img src="https://i-blog.csdnimg.cn/blog_migrate/77837c3ef3ee4f8adfe60825294c2e90.png" width="80%" alt=""/>
总结:改成下面的代码即可改变width比例。(好嘞,去美化我之前的博客去咯)
<img src=" 图片的链接 " width="80%" alt=""/>