删除基于索引c#的列表项

时间:2016-07-18 18:46:18

标签: c# arrays list indexof

我有两个清单。 第一个列表包含字母和数字等值。 长度为[0] - [36]。 第二个列表包含相似的值,长度也是[0] - [36]。

我使用特定值迭代第二个列表以获取索引键,当我从第二个列表中获取索引键时,我想根据第二个列表中的索引删除第一个列表中的项目。

问题是第二次迭代不再起作用,因为索引键在第一个列表中已经改变。

我应该将list转换为数组(数组有固定索引键,list生成后)但我不知道如何从数组中添加或删除索引键。

我不使用Linq。

感谢您的帮助和建议 BR

代码示例:

List<int> list_z = new List<int>();
List<int> list_k = new List<int>();

for (int i = 0; i < second_list.Count; i++) {
    if (second_list[i] == "K")
    {
    list_k.Add(i);
    }
}

int k = list_k.Count; 

for (int i = 0; i < k; i++) {
    first_list.RemoveAt(list_k[i]);
}

for (int i = 0; i < second_list.Count; i++)
{
    if (second_list[i] == "Z")
    {
    list_z.Add(i);
    }
}

int z = list_z.Count;
for (int i = 0; i < svi_z; i++)
    first_list.RemoveAt(lista_z[i]); //here is error, because first_list doesnt have index key number 36 anymore
}

3 个答案:

答案 0 :(得分:3)

当根据索引从列表中删除项目时,您应该以降序删除它们(例如,您应该按此顺序删除第11,第8,第3,第2项)。在你的情况下:

  list_k.Sort();

  for (int i = list_k.Count - 1; i >= 0; --i)
    first_list.RemoveAt(list_k[i]);

答案 1 :(得分:3)

有一个简单的解决方案,可以一个接一个地从特定索引中删除列表中的项目。也就是命令索引降序,这样你就不会在列表中移动任何项目。

示例:

The Below抛出错误:

List<int> list = Enumerable.Range(0, 20).ToList();

List<int> indexesToRemove = new List<int>(){ 5, 13, 18 };

foreach(int i in indexesToRemove)
{
    list.RemoveAt(i);
}

如果你这样做,你将不会得到任何错误:

List<int> list = Enumerable.Range(0, 20).ToList();

List<int> indexesToRemove = new List<int>(){ 5, 13, 18 };

foreach(int i in indexesToRemove.OrderByDescending(x => x))
{
    list.RemoveAt(i);
}

所以在你的情况下,你只需要在循环之前调用list_z = list_z.OrderByDescending(x => x).ToList();,一切都应该正常。

或者,如果您不想使用linq,您可以执行以下操作:

list_z.Sort((x, y) => y - x);
for (int i = 0; i < list_z.Count; i++)
    first_list.RemoveAt(lista_z[i]);
}

答案 2 :(得分:1)

或者你可以简化你的工作:

        // Iterate and assign null
        for (var i = 0; i < second_list.Count(); i++)
        {
            if (second_list[i] == "K")
            {
                first_list[i] = null;
            }
        }

        // Iterate and assign null
        for (var i = 0; i < second_list.Count; i++)
        {
            if (second_list[i] == "Z")
            {
                first_list[i] = null;
            }
        }

        // remove nulls without linq or lambda
        first_list.RemoveAll(delegate (string o) { return o == null; });