可能重复:
列表索引搜索
我必须在值相同的 int[] 中获取索引,因此我必须在 int[] 中获取相同值的所有索引 num。
前任。
int[] xx = {4,5,4,3,2}
我在用
Array.indexOf(xx, 4);
它会返回 0,但我想得到 0 和 2。
怎么样
int[] xx = {4,5,4,3,2};
int search = 4;
var result = xx.Select((b, i) => b.Equals(search) ? i : -1).Where(i => i != -1);
在这里阅读我的原始答案。
我认为没有任何内置的单行代码(Nikhil 的方法与 LINQ 一样接近),但它很容易编写:
public static IEnumerable<int> FindAllIndexes(this IEnumerable<T> haystack,
T needle) where T : IEquatable<T>
{
int index = 0;
foreach (var item in haystack)
{
if (item.Equals(needle))
{
yield return index;
}
index++;
}
}
将其用作:
foreach (var index in array.FindAllIndexes(4))
{
...
}
如果您真的愿意,可以使用自定义比较器编写重载。
using System;
using System.Linq;
class Program
{
static void Main(string[] args)
{
int[] xx = { 4, 5, 4, 3, 2 };
int findValue = 4;
var indexes = xx.Select((val, index) => new { Value = val, Index = index })
.Where(x => x.Value == findValue)
.Select(x => x.Index);
foreach (var index in indexes)
Console.WriteLine(index);
}
}
您可以通过使用迭代器来做到这一点。
public IEnumerable<int>
GetIndexes(int[] xx, int toSearch )
{
// Yield even numbers in the range.
for (int i= 0; i < xx.Length; i++)
{
if (xx[i] == toSearch)
{
yield return xx[i];
}
}
}
您可以简单地使用这样的方法(如果可以使用序列而不是数组):
static IEnumerable<int> AllIndexesOf(int[] xx, int value) {
for (int i = 0; i < xx.Length; ++i) {
if (xx[i] == 4) {
yield return i;
}
}
}