这就是我所拥有的:
int[] indexes; // it contains indexes that are "good"
string[] words; // many words
List<string> result;
我想做这个代码:
for (int i = 0; i < words.Count(); ++i)
if (indexes.Contains(i))
result.Add(words[i]);
只有一行,LINQ我猜:)怎么样?
答案 0 :(得分:7)
假设一组不同的索引。我们可以抓住每个单词而不是从单词开始并找到匹配的索引。
List<string> result = indexes.Select(i => words[i]).ToList();
请注意,假设索引小于单词,此版本会快得多。 (100个索引和20,000个单词将是你的2000万次操作和我的100次操作)。
答案 1 :(得分:1)
嗯,不是一个班轮而是:
result = Enumerable.Range(0, words.Count())
.Where(indexes.Contains)
.Select(idx => words[idx])
.ToList();