力扣80删除有序数组的重复

本题用通解,k这里为2,

1.本题目是有序数组,允许有两个数字重复,就例如11223344,前k(即2个)个是肯定可以保存的,到第三个即以后的就要比较了。

用pos表示当前要放的数的位置下标,此位置放的数必须与该位置的前面k个数的第一个数不同,因为假设k=2,序列为112,这里2只用于第一个1不同,因为毎k个为一组,只允许k个重复。

所以用一个num遍历数组,pos<k前k个肯定首先不用考虑,所以另个判断条件即使数组越界了也没事,因为到不了那个判断那里,然后从第k个就可以开始放了,毎放一个,pos+1。

而放不放的条件就是判断这个数是否与要放到位置的向前数第k个数不同。

2.这两个写法等价

cpp 复制代码
for (auto i : nums)
cpp 复制代码
for(int i=0;i<nums.size();i++)

3.未知长度数组连续键入值存入数组How

while((scanf("%d",&a))!=EOF)

4.代码

cpp 复制代码
class Solution {
public:
    int removeDuplicates(vector<int>& nums) {
	int k = 2;
	int pos = 0;
	for (auto num : nums) {
		if (pos < k || nums[pos - k] != num) {
			nums[pos] = num;
			pos++;
		}
	}
	return pos;
}


};
相关推荐
希望永不加班几秒前
SpringBoot 静态资源访问(图片/JS/CSS)配置详解
java·javascript·css·spring boot·后端
ZHOU_WUYI1 分钟前
ppo算法简单实现
人工智能·pytorch·算法
oh LAN16 分钟前
RuoYi-Vue-master:Spring Boot 4.x (JDK 17+) (环境搭建)
java·vue.js·spring boot
ch.ju23 分钟前
Java程序设计(第3版)第二章——java的数据类型:小数
java
无限进步_33 分钟前
【C++】巧用静态变量与构造函数:一种非常规的求和实现
开发语言·c++·git·算法·leetcode·github·visual studio
Advancer-36 分钟前
RedisTemplate 两种序列化实践方案
java·开发语言·redis
小超超爱学习99371 小时前
大数乘法,超级简单模板
开发语言·c++·算法
java1234_小锋1 小时前
Java高频面试题:MyBatis如何实现动态数据源切换?
java·开发语言·mybatis
墨神谕1 小时前
Java中,为什么要将.java文件编译成,class文件,而不是直接将.java编译成机器码
java·开发语言
Ricardo-Yang1 小时前
SCNP语义分割边缘logits策略
数据结构·人工智能·python·深度学习·算法