题目要求
- 原地 (输入的资料通常会被要输出的部分覆盖掉)删除重复出现的元素
- 输出数组的长度和内容
- 空间复杂度O(1)
int[] nums = [...]; // 输入数组
int[] expectedNums = [...]; // 长度正确的期望答案
int k = removeDuplicates(nums); // 调用
assert k == expectedNums.length;
for (int i = 0; i < k; i++) {
assert nums[i] == expectedNums[i];
}
########################################
class Solution:
def removeDuplicates(self, nums: List[int]) -> int:
代码
由 int k = removeDuplicates(nums); // 调用:
可知函数输入为数组,输出为数组长度。
双指针法:
python3:
class Solution:
def removeDuplicates(self, nums: List[int]) -> int:
lenth = len(nums)
i = 0
j = 1
while j < lenth :
if nums[i] != nums[j]:
i = i + 1
nums[i] = nums[j]
j = j + 1
return i + 1
//////////////
if __name__ == '__main__':
nums = list(map(int, input('请输入有序数组:').split()))
print(nums[:removeDuplicates(nums)])
c++版:
class Solution {
public:
int removeDuplicates(vector<int>& nums) {
int length = nums.size();
if (length == 0) return 0;
int slow = 0, fast = 1;
while (fast < length) {
if (nums[fast] != nums[slow]) {
nums[++slow] = nums[fast];
}
fast++;
}
return slow + 1;
}
};
逆序删除法:
class Solution:
def removeDuplicates(self, nums: List[int]) -> int:
for i in range(len(nums) - 1, 0, -1):
if nums[i] == nums[i - 1]:
del nums[i]
return len(nums)
for i in range(len(nums) - 1, 0, -1):
1.for i in sequence :为for循环,sequence为可迭代对象:列表,字典,字符串,元组,集合等。
2.rang():用于生成一系列连续整数,左闭右开[len(nums)-1,0),-1表示反向且步长为1
del nums[i]
del函数:python的del不同于C的free(负责将 malloc() 函数申请的空间给释放掉)和C++的delete(用于释放new[]分配的内存空间)。由于python都是引用,而python有GC机制,所以,del语句作用在变量上,而不是数据对象上。del删除的是变量,而不是数据。
if __name__=='__main__':
a=1 # 对象 1 被 变量a引用,对象1的引用计数器为1
b=a # 对象1 被变量b引用,对象1的引用计数器加1
c=a #1对象1 被变量c引用,对象1的引用计数器加1
del a #删除变量a,解除a对1的引用
del b #删除变量b,解除b对1的引用
print(c) #最终变量c仍然引用1
if __name__=='__main__':
li=[1,2,3,4,5] #列表本身不包含数据1,2,3,4,5,而是包含变量:li[0] li[1] li[2] li[3] li[4]
first=li[0] #拷贝列表,也不会有数据对象的复制,而是创建新的变量引用
del li[0]
print(li) #输出[2, 3, 4, 5]
print(first) #输出 1
总结
1. python和cpp的区别 :
1). cpp的if和while条件要有(),后续操作要有{ },相反python直接冒号:不用中括号,其缩进及其严格。
2). cpp定义变量时前要有数据类型约束(定义函数时函数名前也要有数据类型),相反python不用约束直接取名定义变量。
3). cpp每行代码结尾都要有分号;而python则不用
2.for循环(python): ↑
3.range()函数(python): ↑
4.del函数(python): ↑
5.有序数组去重(原地算法)空间复杂度O(1):
双指针法and逆序删除法(第二种空间占用率更低)