力扣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;
}


};
相关推荐
C雨后彩虹2 分钟前
CAS与其他并发方案的对比及面试常见问题
java·面试·cas·同步·异步·
_不会dp不改名_26 分钟前
leetcode_3010 将数组分成最小总代价的子数组 I
算法·leetcode·职场和发展
java1234_小锋1 小时前
Java高频面试题:SpringBoot为什么要禁止循环依赖?
java·开发语言·面试
2501_944525541 小时前
Flutter for OpenHarmony 个人理财管理App实战 - 账户详情页面
android·java·开发语言·前端·javascript·flutter
计算机学姐1 小时前
基于SpringBoot的电影点评交流平台【协同过滤推荐算法+数据可视化统计】
java·vue.js·spring boot·spring·信息可视化·echarts·推荐算法
Filotimo_2 小时前
Tomcat的概念
java·tomcat
索荣荣2 小时前
Java Session 全面指南:原理、应用与实践(含 Spring Boot 实战)
java·spring boot·后端
你撅嘴真丑2 小时前
字符环 与 变换的矩阵
算法
Amumu121382 小时前
Vue Router(二)
java·前端