如何从已排序数组中移除重复项,并使用 C# 返回非重复数组?
该数组已经过排序,我们可以保持两个指针 ii 和 jj,其中 ii 是慢速指针,而 jj 是快速指针。只要 nums[i] = nums[j]nums[i]=nums[j],我们就递增 jj 以跳过重复项。
当我们遇到 nums[j] != nums[i] 时,重复项已经结束,所以我们必须将其值复制到 nums[i + 1]nums[i+1]。然后递增 ii,我们再次重复相同的过程,直到 jj 达到数组末尾。创建一个新数组,复制过滤后的数组,直到索引并返回新数组。
时间复杂度 - O(N)
示例
using System;
namespace ConsoleApplication{
public class Arrays{
public int[] RemoveDuplicatesFromSortedArrayAndReturnArray(int[] arr){
int index = 1;
for (int i = 0; i < arr.Length - 1; i++){
if (arr[i] != arr[i + 1]){
arr[index] = arr[i + 1];
index++;
}
else{
continue;
}
}
int[] newarr = new int[index];
for (int i = 0; i < index; i++){
newarr[i] = arr[i];
}
return newarr;
}
}
class Program{
static void Main(string[] args){
Arrays a = new Arrays();
int[] arr = { 0, 0, 1, 1, 1, 2, 2, 3, 3, 4 };
int[] res = a.RemoveDuplicatesFromSortedArrayAndReturnArray(arr);
for (int i = 0; i < res.Length; i++){
Console.WriteLine(res[i]);
}
Console.ReadLine();
}
}
}输出
0 1 2 3 4
广告
数据结构
网络
关系型数据库管理系统
操作系统
Java
iOS
HTML
CSS
Android
Python
C 编程
C++
C#
MongoDB
MySQL
Javascript
PHP