更改 remove 方法以从数组中获取元素并将最后一个值移动到其位置
本文关键字:最后一个 移动 位置 元素 方法 remove 数组 获取 更改 | 更新日期: 2023-09-27 18:31:55
正如标题所暗示的那样,在 C# 中,我正在尝试更改此 remove 方法,以获取数组中的最后一项并将其移动到已删除的值的位置。 这样,当您删除元素时,它不必采用每个单独的数字并将其向上移动一个空格。
这是我当前的代码:
public override void remove(ref T item)
{
if (next == 0)
{
}
else
{
//find value, if it exists
for (int i = 0; i < next; i++)
{
if (item.Equals(list[i]))
{
for (int j = i; j < next; j++) list[j] = list[j + 1];
next--;
break;
}
}
}
}
任何帮助将不胜感激。
这是我将值插入数组的代码。
{
UnorderedArrayList<int> u = new UnorderedArrayList<int>();
u.print();
int var = 5;
u.insert(ref var);
var = 12;
u.insert(ref var);
var = 2;
u.insert(ref var);
var = 29;
u.insert(ref var);
u.print();
var = 5;
u.remove(ref var);
u.print();
}
您所要做的就是将内部循环替换为移动最后一项的代码,然后清除最后一项:
public override void remove(ref T item)
{
// find value, if it exists
for (int i = 0; i < next; i++)
{
if (item.Equals(list[i]))
{
list[i] = list[next-1];
list[next-1] = default(T);
next--;
break;
}
}
}
无需在开始时检查next == 0
,因为for
条件会检查它。如果next == 0
,则循环不会进行任何迭代。
找到该项后,代码只需移动最后一项以替换找到的索引处的项。然后,它将最后一项设置为 default(T)
(对于引用类型将null
该项)。如果你不这样做,你最终会出现内存泄漏:存储对你认为你删除的东西的引用。它不会影响列表的操作,但可能会导致您使用比预期更多的内存。
对于一些 LINQy 的优点:
public static IEnumerable<T> ShuffleRemove<T>(this IEnumerable<T> enumerable, T item)
{
var count = enumerable.Count();
var last = enumerable.ElementAt(count - 1);
var found = false;
for (int i = 0; i < count - 1; i++)
{
var current = enumerable.ElementAt(i);
if (!found && item.Equals(current))
{
yield return last;
found = true;
}
else
{
yield return current;
}
}
yield break;
}
用法:
var array = new int[] { 1, 2, 2, 3, 4, 5 };
array.ShuffleRemove(2); // returns: 1, 5, 2, 3, 4
如果需要它将所有 2 替换为 5,请删除所有found
项。