最佳算法是什么以从一个列表中删除项目,该列表在删除项目时重新索引?

huangapple go评论81阅读模式
英文:

What's the best algorithm to remove items from a list that is reindexed when an item is removed?

问题

我处理的可能是一个常见情况,我甚至不知道如何用搜索来表达。

我决定寻求指导,不一定要得到任何代码片段,而是询问在这种情况下最佳的处理方法。

我有一个名为arrIntIndexesOfJobsThatWillBeKilled的列表,其中包含必须从另外5个列表中移除的项目的原始索引。

然而,当我从其他5个列表中移除一个项目时,它们被重新索引,我曾经在arrIntIndexesOfJobsThatWillBeKilled中拥有的索引现在无效了。

我想要仅删除与原始索引相关联的项目...

如何处理这种情况的最佳算法是什么?

  1. arrIntIndexesOfJobsThatWillBeKilled = arrIntIndexesOfJobsThatWillBeKilled.Distinct.ToList
  2. If arrIntIndexesOfJobsThatWillBeKilled.Count > 0 Then
  3. For Each Job As Integer In arrIntIndexesOfJobsThatWillBeKilled
  4. arrStrJobDescription2.RemoveAt(Job)
  5. arrStrPNDirectories2.RemoveAt(Job)
  6. arrIntJobIDDirectories2.RemoveAt(Job)
  7. arrStrSubDirectories2.RemoveAt(Job)
  8. arrStrNCFile2.RemoveAt(Job)
  9. Next
  10. End If
英文:

I'm dealing with a probably common situation that I don't even know how to formulate in a search.

I decided to ask for guidance, not necessarily to get any piece of code but to ask about what is the best approach for this kind of situation.

I have a list named arrIntIndexesOfJobsThatWillBeKilled containing the original indexes of the items that must be removed from another 5 lists.

However, when I remove an item from the other 5 lists, they are reindexed, and the indexes I once had in arrIntIndexesOfJobsThatWillBeKilled are now invalid.

I want to remove only the items linked to the original indexes...

What is the best algorithm to handle this situation?

  1. arrIntIndexesOfJobsThatWillBeKilled = arrIntIndexesOfJobsThatWillBeKilled.Distinct.ToList
  2. If arrIntIndexesOfJobsThatWillBeKilled.Count > 0 Then
  3. For Each Job As Integer In arrIntIndexesOfJobsThatWillBeKilled
  4. arrStrJobDescription2.RemoveAt(Job)
  5. arrStrPNDirectories2.RemoveAt(Job)
  6. arrIntJobIDDirectories2.RemoveAt(Job)
  7. arrStrSubDirectories2.RemoveAt(Job)
  8. arrStrNCFile2.RemoveAt(Job)
  9. Next
  10. End If

答案1

得分: 3

你可以更改移除顺序以反转删除较大索引的顺序。我不太熟悉VB,但在C#中,它看起来会像这样:

  1. arrIntIndexesOfJobsThatWillBeKilled = arrIntIndexesOfJobsThatWillBeKilled
  2. .OrderByDescending(i => i) // 假设这里是整数列表,或者 .OrderDescending() 适用于较新的框架
  3. .Distinct()
  4. .ToList();

然后继续执行删除。

P.S.

If arrIntIndexesOfJobsThatWillBeKilled.Count > 0 Then 的检查是多余的 - foreach 可以很好地处理空集合。

英文:

You can change the order of removal to reverse one - delete bigger indexes first. Not fluent with VB, but in C# it will look like:

  1. arrIntIndexesOfJobsThatWillBeKilled = arrIntIndexesOfJobsThatWillBeKilled
  2. .OrderByDescending(i => i) // assuming list of integers here, or .OrderDescending() for later framework
  3. .Distinct()
  4. .ToList();

And then proceed with deletion.

P.S.

If arrIntIndexesOfJobsThatWillBeKilled.Count > 0 Then check is redundant - foreach handles empty collections just fine.

答案2

得分: 0

以下是已翻译好的代码部分:

  1. 如果 arrIntIndexesOfJobsThatWillBeKilled.Count > 0 Then
  2. arrIntIndexesOfJobsThatWillBeKilled = arrIntIndexesOfJobsThatWillBeKilled.OrderByDescending(Function(i) i).Distinct.ToList
  3. For Each Job As Integer In arrIntIndexesOfJobsThatWillBeKilled
  4. arrStrJobDescription2.RemoveAt(Job)
  5. arrStrPNDirectories2.RemoveAt(Job)
  6. arrIntJobIDDirectories2.RemoveAt(Job)
  7. arrStrSubDirectories2.RemoveAt(Job)
  8. arrStrNCFile2.RemoveAt(Job)
  9. Next
  10. End If
英文:

After the guidance of the collaborators here, this is the code that works:

  1. If arrIntIndexesOfJobsThatWillBeKilled.Count > 0 Then
  2. arrIntIndexesOfJobsThatWillBeKilled = arrIntIndexesOfJobsThatWillBeKilled.OrderByDescending(Function(i) i).Distinct.ToList
  3. For Each Job As Integer In arrIntIndexesOfJobsThatWillBeKilled
  4. arrStrJobDescription2.RemoveAt(Job)
  5. arrStrPNDirectories2.RemoveAt(Job)
  6. arrIntJobIDDirectories2.RemoveAt(Job)
  7. arrStrSubDirectories2.RemoveAt(Job)
  8. arrStrNCFile2.RemoveAt(Job)
  9. Next
  10. End If

Many thanks for once again educating this mediocre coder...

huangapple
  • 本文由 发表于 2023年5月22日 15:37:01
  • 转载请务必保留本文链接:https://go.coder-hub.com/76303931.html
匿名

发表评论

匿名网友

:?: :razz: :sad: :evil: :!: :smile: :oops: :grin: :eek: :shock: :???: :cool: :lol: :mad: :twisted: :roll: :wink: :idea: :arrow: :neutral: :cry: :mrgreen:

确定